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(54) Computer platforms and their methods of operation 



(57) A computer platform ( 1 00) uses a tamper-proof 
component (120), or "trusted module", of a computer 
platform in conjunction with software, preferably running 
within the tamper-proof component, that controls the up- 
loading and usage of data on the platform as a generic 
dongle for that platform. Licensing checks can occur 
witftln a trusted environment (in other words, an envi- 



ronment which can be trusted to behave as the user ex- 
pects); this can be enforced by integrity checking of the 
uploading and licence-checking software. Metering 
records can be stored in the tamper-proof device and 
reported back to administrators as required. There can 
be an associated clearinghouse mechanism to enable 
registration and payment for data. 
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Description 

[0001] This invention relates to computer platforms 
and their methods of operation and is more particularly 
concerned with controlling and/or metering the installa- 
tion and/or use ot data on computer platforms. 
[0002] In this specification, 'data' signifies anything 
that can be formatted digitally, such as images, applica- 
tion software and streaming media. The techniques de- 
scribed in this document can potentially be used to pro- 
tect or meter many types of information, from simple text 
documents to audio and video clips, software, graphics, 
photo- and multimedia materials. 

[0003] In the future, computer systems will be able to 
achieve a more secure booting, together with integrity 
checks on other code to ensure that viruses or other un- 
authorised modifications have not been made to the op- 
erating systems and mounted software. In addition, a 
new generation of tamper-proof devices are already ap- 
pearing or will soon appear on the market and include 
both external or portable components (such as smart 
cards) and internal components (embedded proces- 
sors, semi-embedded processors or co-processors with 
security functionality, i.e. including motherboard, USB 
and ISA implementations). These tamper-proof compo- 
nents will be used to check that the hardware of the sys- 
tem has not been tampered with, and to provide a more 
reliable form of machine identity than currently available 
(for example, the machine's Ethernet name). Yet how to 
counteract piracy, and how to licence and meter soft- 
ware in a manner that is acceptable to software devel- 
opers and end-users will still be a very important prob- 
lem. 

[0004] Software licensing is subject to hackers and pi- 
racy, and all the current software licensing methods 
used have problems associated with them. Software im- 
plementations of licensing (such as "licence manage- 
ment systems") are flexible, but not especially secure or 
fast. In particular, they suffer from a lack of security (for 
example, being subject to a generic "hack") and difficulty 
in genuine replacement of software. Conversely, hard- 
ware implementations ("dongles") are faster and gener- 
ally more secure than software implementations: but in- 
flexible. They are tailored only for a particular piece of 
software and are inconvenient for end-users. 
[0005] The present invention, in its preferred embod- 
iment, seeks to deliver the best of both worlds: a hard- 
ware implementation that is secure and fast, but with the 
convenience and flexibility of a software implementa- 
tion. Increased security in integrity checking on compu- 
ter platforms, together with more secure key storage, 
cryptographic capabilities and more secure identifica- 
tion (and hence authentication) within tamper-resistant 
hardware are provided in the embodiment of this new, 
generic concept in software licensing and metering. 
[0006] A prior patent application (EP 99301100.6) 
described the use of a Trusted Component to enable 
verification of the integrity of a computer platform by the 



reliable measurement and reliable reporting of integrity 
metrics. This enables the verification of the integrity of 
a platform by either a local user or a remote entity. That 
prior patent application described a general method of 

5 reporting integrity metrics and verifying the correctness 
of the integrity of a platform by comparing reported val- 
ues of metrics with proper values of metrics. The present 
invention uses licence checking code whose integrity is 
reported using the method of that prior patent applica- 

10 tion. 

[0007] In overview, the embodiment of the present in- 
vention uses a tamper-proof component, or "trusted 
module" of a computer platform in conjunction with soft- 
ware, preferably running within the tamper-proof com- 

75 ponent, that controls the uploading and usage of data 
on the platform as a generic dongle for that platform. 
Licensing checks can occur within a trusted environ- 
ment (in other words, an environment which can be 
trusted to behave as the user expects); this can be en- 

20 forced by integrity checking of the uploading and li- 
cence-checking software. Metering records can be 
stored in the tamper-proof device and reported back to 
administrators as required. There can be an associated 
clearinghouse mechanism to enable registration and 

25 payment for data. 

[0008] More formally, in accordance with a first aspect 
of the present invention, there is provided a computer 
platform having: a trusted module which is resistant to 
internal tampering and which stores a third party's public 

30 key certificate; means storing licence-related code com- 
prising at least one of: a secure executor (which is pref- 
erably generic) for checking whether the platform or a 
user thereof is licensed to use particular data and for 
providing an interface for using the data and/or for mon- 

3S itoring its usage; and a secure loader (which is prefera- 
bly generic) for checking whether the platform or a user 
thereof is licensed to install particular data and/or for 
checking for data integrity before installation; and 
means storing a hashed version of the licence-related 

40 code signed with the third party's private key; wherein 
the computer platform is programmed so that, upon 
booting of the platform: the licence-related code is in- 
tegrity checked with reference to the signed version and 
the public key certificate; and if the integrity check fails, 

45 the licence-related code is prevented from being loaded. 
If the integrity check fails, it may be arranged that the 
complete platform integrity fails. 

[0009] In the context of this specification, the term "us- 
er" includes may mean an end user of the platform, or 

50 a system administrator, or both. 

[0010] The trusted module or component, as de- 
scribed in the prior patent application mentioned above 
is preferably immune to unauthorised modification or in- 
spection of internal data. It is physical to prevent forgery, 

55 tamper-resistant to prevent counterfeiting, and prefera- 
bly has crypto functions to securely communicate at a 
distance. Methods of building trusted modules are, per 
se, well known to those skilled in the art. The trusted 
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module may use cryptographic methods to give itself a 
cryptographic identity and to provide authenticity, integ- 
f rity, confidentiality, guard against replay attacks, make 
digital signatures, and use digital certificates as re- 
quired. These and other crypto methods and their ini- 5 
tialisation are well known to those skilled in the art of 
security. 

[0011] Preferably, the integrity checking is performed 
by: reading and hashing the licence-related code to pro- 
duce a first hash; reading and decrypting the signed ver- 10 
sion using the public key certificate to produce a second 
hash; and comparing the first and second hashes. 
[0012] Preferably, the licence-related code also in- 
cludes secure key-transfer code for enabling a licence 
key to be transferred between the trusted module and is 
a further trusted module of another computer platform. 
This key transfer code is particularly useful in improving 
key management when using licensing models that in- 
volve an unlock key, that is, where the data is transmit- 
ted in an encrypted form and the unlock key is used to 20 
allow the protected data to be decrypted and run. The 
transfer may be carried out by using a public key infra- 
structure to encrypt a message containing an unlock 
key, and checking for integrity via hashing and digital 
signatures. There may be an option to transfer the data 25 
itself in this manner, using the secure loader. 
[0013] Preferably, the licence-related code also in- 
cludes a library of interface subroutines which can be 
called in order to communicate with the trusted module. 
The client library is a collection of high-level interlace 30 
subroutines that applications call to communicate with 
the trusted module. The client library may also be used 
by software executors (see below) for communication 
with the trusted module and operating system ('OS'). 
[0014] The licence-related code may include, for at 35 
least one group of data, a (or a respective) software ex- 
ecutor which specifies the respective group of data and 
which is operable to act as an interface to that group of 
data. This allows methods of licensing protection spe- 
cific to the protected data, and therefore potentially a 40 
greater level of protection. If a software executor is as- 
sociated with an application, optionally it processes que- 
ries (API calls) submitted by the application. 
[001 5] Preferably, if space permits, the means storing 
the licence-related code and/or the means storing the 45 
hashed version of the licence-related code are provided, 
at least in part, by the trusted module. 
[0016] Preferably, the trusted module and an operat- 
ing system of the platform have a dedicated communi- 
cations path therebetween which is inaccessible to oth- so 
er parts of the computer platform. 

[001 7] Next the way in which these components inter- 
act to form a system for general -purpose data licensing 
will be considered. There are several stages in which 
such a system can be constructed, which may be con- ss 
sidered as progressing from each other. The first stage 
is to improve upon current licensing methods such as 
dongles to make the trusted module act as a generic 



dongle, governed by generic licence-related software 
(as detailed above) that performs licence checking and 
is protected against bypassing by integrity checking. 
Such licence-checking software need not run within the 
trusted module itself. A preferred stage is the logical ex- 
tension of such a system in which the licensing software 
runs within the trusted module. A request to load or ex- 
ecute some data will be sent to the trusted module, pref- 
erably from the software executor. The licensing soft- 
ware in the trusted module will evaluate such a request 
and decide whether to allow this, based on details of 
licensing rights. If the request is to be allowed ; this in- 
formation is conveyed to the OS via a hardware com- 
munications path from the trusted module to the CPU. 
The communications path is preferably inaccessible to 
ordinary applications and non-OS software. The OS 
then starts the process to load or execute the data, as 
appropriate. 

[0018] Various methods are now considered in which 
the system components may interact to perform useful 
licensing functionality. First consideration is given to the 
way in which the secure loader operates to install data. 
[0019] In one installation mode: the operating system 
is operable to request the secure loader to licence- 
check whether the platform or a user thereof (e.g. an 
end user or a system administrator) is licensed to install 
that particular data and/or to check the integrity of that • 
data; in response to such a request, the secure loader 
is operable to perform such a check and respond to the 
operating system with the result of the check; and in de- 
pendence upon the response, the operating system is 
operable to install or not to install the particular data. 
This check on the platform or user may be performed 
by various methods, such as checking for the presence 
of a private application key or other secret in the trusted 
module or in a smart card, or checking for the identity 
and presence of the trusted module or smart card. Such 
an identity could be made known to the developer, or 
such a secret could be inserted into the trusted module 
or smart card during a registration process. This is anal- 
ogous to the process which will be described later in Ex- 
ample A. 

[0020] In this mode, preferably the operating system 
is programmed to install the particular data only in re- 
sponse to the secure loader. Also, in this mode, prefer- 
ably: the trusted module stores a public key certificate 
for a party associated with the particular data to be in- 
stalled; the operating system is operable to include, in 
the request to check, the particular data together with a 
hashed version thereof signed with a private key of the 
associated party; in performing the check, the secure 
loader is operable: to hash the particular data included 
in the request to produce a third hash; to decrypt the 
signed hashed version in the request using the public 
key certificate for the associated party to produce a 
fourth hash; and to generate the response in depend- 
ence upon whether or not the third and fourth hashes 
match. 
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[0021] This checks for integrity oi the message. The 
integrity checking mechanism also prevents replay at- 
tacks by using a standard mechanism, such as chal- 
lenge/response, or introducing a history of the commu- 
nications in the hash. The problem of non-repudiation 
can be avoided by keeping private keys in tamper proof 
hardware. Preferably, the request to check includes the 
software executor for the particular data. 
[0022] In another installation mode: the software ex- 
ecutor (or at least one of the software executors) is op- 
erable to request the trusted module to install particular 
data; in response to such a request, the secure loader 
within the trusted module is operable to licence-check 
whether the platform or a user thereof is licensed to in- 
stall that particular data and/or to check the integrity of 
that data and to respond to the operating system with 
the result of the check; and in dependence upon the re- 
sponse, the operating system is operable to install or 
not to install the particular data. 

[0023] The check may be carried out in a similar fash- 
ion to that described above in relation to said one instal- 
lation mode. 

[0024] In this other mode, preferably the operating 
system is programmed to install the particular data only 
in response to the trusted module. Also, in this mode, 
preferably the response from the trusted module to the 
operating system is supplied via the dedicated commu- 
nications path, as described above. 
[0025] With either of these installation modes, if the 
check succeeds, the trusted module is preferably oper- 
able to generate a log for auditing the particular data. 
Also, if the check succeeds, the secure loader is prefer- 
ably operable to perform a virus check on the particular 
data. 

[0026] Upon installation, the particular data may be 
installed into the trusted platform. Alternatively, the plat- 
form may include a further, removable, trusted module 
(such as a smart card) and be operable to perform an 
authentication check between the first-mentioned trust- 
ed module and the removable trusted module, in which 
case ; upon installation, the particular data may be in- 
stalled into the further trusted module. 
[0027] The software executor may itself be protected 
via integrity checks, carried out by the secure loader. 
For example, this procedure may work as follows: 

(a) The software executor is customised such that 
the public key corresponding to the client's trusted 
module is included within it. 

(b) The data, associated with a customised soft- 
ware executor, is sent to the client. 

(c) Both the data and the software executor are 
hashed and signed with the clearinghouse/develop- 
er's private key, and this is sent in conjunction with 
the data and software executor 



10 



(d) The secure loader integrity checks the software 
executor when it is received - upon installation of 
the software executor, the package is verified by 
hashing and comparison with the decrypted signa- 
ture (using the public key in the trusted module). 
The software executor is not loaded if the digital sig- 
nature does nol match what is expected, and in this 
case the secure loader signals an error. The secure 
loader also integrity checks the data itself, using the 
same procedure. 



[0028] Now, consideration is given to the way in which 

the secure executor operates to use data. 

[0029] In a first execution mode: the software execu- 

15 tor (or at least one of the software executors) contains 
a public key of the trusted module and a licensing model 
for the respective data; the operating system is operable 
to request that software executor that its respective data 
be used; in response to such a request, that software 

20 executor is operable to request the secure executor to 
licence-check, using its licensing model, whether the 
platform or a user thereof is licensed to use that data; 
in response to such latter request, the secure executor 
is operable to perform the requested licence-check, to 

25 sign the result of the licence check using a private key 
of the trusted module, and to respond to that software 
executor with the signed result; in response to such a 
response, that software executor is operable: to check 
the integrity of the signed result using the public key of 

30 the trusted module; and upon a successful integrity 
check of a successful licence-check result, to request 
the operating system to use that data. 
[0030] In a second execution mode: the software ex- 
ecutor (or at least one of the software executors) con- 

35 tains a public key of the trusted module and a licensing 
model for the respective data; the operating system is 
operable to request the secure executor that particular 
data be used; in response to such a request, the secure 
executor is operable to send to the respective software 

40 executor a request, signed using a private key of the 
trusted module, for a licensing model for the particular 
data; in response to such latter request, that software 
executor is operable: to check the integrity of the request 
using the public key of the trusted module; and upon a 

45 successful integrity check, to send the licensing model 
to the secure executor; and upon receipt of the licensing 
model, the secure executor is operable: to perform a li- 
cence-check using that licensing model; and upon a 
successful licence-check, to request the operating sys- 

50 tern to use that data. 

[0031] In a third execution mode: the secure executor 
contains at least one licensing model; the operating sys- 
tem is operable to request the secure executor that par- 
ticular data be used; and in response to such a request, 

55 the secure executor is operable: to perform a licence- 
check using the, or one of the, licensing models; and 
upon a successful licence-check, to request the operat- 
ing system to use that data. 
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[0032] With any of these three execution modes, pref- 
erably the operating system is programmed to use the 
) particular data only in response to the secure executor 
or the software executor. 

[0033] In a fourth execution mode: the secure execu- s 
tor contains at least one licensing model; the software 
executor (or at least one of the software executors) is 
operable to request the trusted module that its respec- 
tive data be used; in response to such a request, the 
secure executor within the trusted module is operable: io 
to perform a licence-check using the, or one of the, li- 
censing models; and upon a successful licence-check, 
to request the operating system to use that data. In this 
case : preferably, the operating system is programmed 
to use the particular data only in response to the trusted is 
module. 

[0034] With any of the second to fourth execution 
modes, the request from the secure executor to the op- 
erating system to use the data is preferably supplied via 
the dedicated communications path. 20 
[0035] With any of the first to fourth execution modes, 
preferably the trusted module is operable to log the re- 
quest to the operating system to use the data. The se- 
curity and reliability of licensing or metering is enhanced 
by securely logging data usage within the trusted mod- 25 
ule. Logging of licensing-related activity is carried out 
and recorded securely in the tamper-proof component. 
There is the option to carry this out at a number of dif- 
ferent stages during licensing. The most common would 
be at the stage at which the data was allowed to run by 30 
the secure executor or software executor. Another com- 
mon point would be at the stage at which the secure 
loader has successfully completed its integrity checks 
on the data to be installed, and has successfully in- 
stalled this data onto the client machine. Since the se- 35 
cure executor, software executor and secure loader are 
protected by integrity checks, some protection is given 
against hackers trying to bypass or edit the logging proc- 
ess. Such logs would provide both secure auditing in- 
formation and the possibility of flexible licensing and 40 
payment models such as pay-per-use, renting, time-de- 
pendent charges, and so on. Such audit logs would form 
the basis for usage reports and information accessible 
to third parties such as the machine user's IT depart- 
ment or company auditors. They would also have com- 45 
mercial value, such as for advertising or giving feedback 
on ratings. 

[0036] In the case where the platform includes a fur- 
ther, removable, trusted module (such as a smart card) 
as mentioned above, it preferably includes a user iden- so 
tity, and : upon licence-checking the secure executor or 
software executor is operable to perform the licence- 
check with reference to the user identity. 
[0037] When the user asks to run software or access 
protected data, the secure executor can perform the li- ss 
cence-check, for example, by: 

(a) Checking for a secret corresponding to a soft- 



ware or data reference, in a device, or 

(b) Using an unlock key to decrypt data and allowing 
it to execute (there are various options for differing 
functionality of the unlock key, including partial un- 
locking of the code), or 

(c) Checking for licensing rights in a database : cor- 
responding to a data reference and a device iden- 
tity, or 

(d) Retrieving a key from a database, correspond- 
ing to a data reference and a device identity, and 
using this to unlock the data. 

[0038] When the user tries to run an application, it 
may be arranged that the secure executor assumes 
overall control, and that it retrieves information from the 
software executor, if one is present, associated with the 
data to find out which specific check is preferred by the 
developer. If a type of check is specified, the secure ex- 
ecutor will carry this out; otherwise it will use a default 
check, as described below. If the check succeeds, the 
secure executor will execute the data. If the check fails, ■ 
the secure executor will prevent the data from being ex- 
ecuted. 

[0039] If the software executor does not specify a li- 1 
censing method, or there is no software executor at-* 
tached to the application, the secure executor may use 
a default protocol that will have been defined for the par- 
ticular machine. This will have been set by the ma- 
chine's administrator with the machine's environment in 
mind; for example, if the machine is only used by one^ 
person, a licensing model corresponding to the internal 
trusted module would probably be most appropriate. It 
will not be possible to bypass the secure executor and 
hence the licensing checks, because the secure exec- 
utor code will have been included within the platform in- 
tegrity check as part of the boot integrity procedure. 
[0040] Different models of licensing use the secure 
executor and software executor in different ways. As will 
be appreciated from the above, it is possible to use them 
in combination, or with either performing the licensing 
checks. There are two main preferred options: 

(1 ) The first option is to have different software ex- 
ecutors attached to each piece of data, governing 
licence checking within the secure executor for 
those particular pieces of data. In some of the ex- 
amples in the next section, the software executors 
communicate directly with the operating system in 
this way. 

(2) An alternative approach is to place more empha- 
sis upon the secure executor, by building up the ge- 
neric code within the platform which carries out the 
checks, and having the secure executor act as a 
bridge between the OS and any software executors. 
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This alternative avoids putting the burden of the pro- 
tocol-writing on the developer, allows Ihe developer 
to specify licensing choices very easily and makes 
use of integrity checking of licence checking code 
when the platform integrity check is made. 



• in return for payment, the database entry corre- 
sponding to the trusted module ID will be updated 
with this key. 

5 [0044] In a second protocol: 



[0041] The software executor associated with a piece 
of data may include any particular information to be 
checked for (obtained during the registration process) 
together with information notifying the secure executor 
within the computer platform about the method of licens- 
ing to be used, the particular trusted device on which to 
make the check, and a reference to the data which is to 
be protected. For example, licensing_method(secret, 
sc,k,w) and licensing_method(secret,tc,k } w) indicate 
that the software referenced by w should be allowed to 
run on a machine only if the secret k is found stored 
within the current smart card or internal trusted compo- 
nent, respectively, of the machine. 
[0042] Different software executors are attached to 
data, with software executors indicating which type of 
licensing model is to be used. The secure executor car- 
ries out a check at runtime, according to this licensing 
model, and does not allow the software w to run unless 
the check succeeds. By these means, communication 
from the clearinghouse to the trusted module specifies 
which licensing protocol the clearinghouse wishes to 
use. 

[0043] Various specific protocols may be employed by 
the secure executor. For example, in a first protocol: 

• the secure executor checks the trusted module ID 
entry or smart card ID entry; 



• optionally, the secure executor downloads data- 
base entries into a profile stored within the trusted 
module; 

10 

• the secure executor checks in an external database 
or a profile stored within the trusted module for li- 
censing rights, corresponding to a data reference 
and the trusted module ID entry (or smart card ID 

75 entry): 

• only if there are appropriate licensing rights, the se- 
cure executor authorises the OS to execute the da- 
ta; and 

20 

• in return for payment, the database entry corre- 
sponding to the trusted module ID or smart card ID 
will be updated with an appropriate permission. 

25 [0045] In a third protocol: 

• the secure executor checks for a secret corre- 
sponding to a software or data reference in a trusted 
module (including a smart card); 

30 

• the secret to be checked for is specified by the soft- 
ware executor associated with the data whose li- 
cence is being checked; and 



optionally, the secure executor downloads data- 
base entries into a profile stored within the trusted 
module; 



35 • only if the secret is present in the trusted module 
will the secure executor authorise the OS to execute 
the associated software or data. 



the secure executor checks in an external database 
or a profile stored within the trusted module against 
a data reference and the trusted module ID entry 
(or smart card ID entry) for an unlock key for the 
data; 

the secure executor retrieves this key and decrypts 
the associated data so that it may be executed by 
the operating system; 

optionally, the secure executor stores the unlock 
key within the trusted module, along with the data 
reference; 

the data is protected via encryption or partial en- 
cryption using the corresponding key; 

there are various options for differing functionality 
of the unlock key; and 



40 



45 



[0046] In a fourth protocol: 

• the secure executor uses an unlock key associated 
with some data stored within the trusted module or 
smart card to decrypt the data so that it may be ex- 
ecuted by the operating system; and 

• there are various options for differing functionality 
of the unlock key, including partial unlocking of the 
code. 



so [0047] In a fifth protocol: 

• the secure executor uses a key associated with 
some data stored within the trusted module or smart 
card, or else inputted from the end-user via the key- 

55 board : the trusted module or smart card ID and a 
pre-defined algorithm to calculate a decryption key; 

• the secure executor uses the decryption key to de- 
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crypt the data so that it may be executed by the op- 
erating system; 

H 

• there are various options for differing functionality 

of the decryption key, including partial unlocking of s 
the code. 

[0048] In a sixth protocol: 

• the secure executor allows use of floating licences 10 
for a group of users; 

• the secure executor checks in a database against 
the trusted module ID or smart card ID entry for a 
licence key for the data; is 

• the secure executor retrieves a licence key (if one 
were available) in order to allow that particular ex- 
ecution; and 

20 

• the secure executor returns the licence key to the 
pool when the data execution is closed. 

[0049] In a seventh protocol: 

• the secure executor performs a combination of any 
the first to sixth protocols, such that different meth- 
ods of licence checking can be used for different 
data entities; 

• the choice of protocol can be determined by the se- 
cure executor itself; 

• a default or overriding protocol can be defined by 
an administrator; and 

• the protocol to be used when checking licensing for 
particular data is determined by any software exec- 
utor associated with that data 

[0050] Some licensing models later described in this 
document do not prevent copying of data, but just inhibit 
unauthorised use of data and secure the logging of us- 
age on machines that have the tamper-proof device as 
part of the platform. The desired level of data protection 
depends upon the business model. Data can be sent via 
traditional and other non-secure channels. However, it 
is most important that the licence key transfer is secure. 
[0051] In accordance with a second aspect of the 
present invention, there is provided a method of trans- so 
ferring a licence (or a key therefor) from a first to a sec- 
ond computer platform each in accordance with the first 
aspect of the invention, the method comprising the steps 
of: setting up secure communication between the trust- 
ed modules; sending the licence or the key therefor from 55 
the first trusted module to the second trusted module 
using the secure communication; and deleting the li- 
cence or the key therefor from the first trusted module. 



25 
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[0052] There are many situations in which a customer 
might wish to transfer a licence to another person or to 
another machine. For example, if a new PC were pur- 
chased, if software is upgraded or replaced, or if the cus- 
tomer wishes to run an application on a portable instead 
of a desktop. Moving a hardware dongle specific to each 
application is the easy solution and there is the analo- 
gous solution of using specific smart cards. However, 
all systems which provide a generic dongle, and there- 
fore are more practical in most situations for end-users, 
are faced with a major problem of key management in 
this situation. Wave System's WaveNet and licence 
management systems ('LMFs') are no exception. Soft- 
ware-only methods require an installation/deinstatlation 
process, or else have to trust the end user to use only 
the number of licences legitimately purchased when a 
second password is issued for the same licence. 
[0053] The options for licence transferral using trust- 
ed modules depend upon the licensing aspect that is 
adopted. In general, these are as follows: 
[0054] For licensing using a database check, the da- 
tabase entries corresponding to both machine trusted 
module IDs (if the licence is changed to another ma- 
chine) or both smart card IDs (if the licence is changed 
to another person) should be changed. 
[0055] For licensing involving a trusted module relat- 
ed finger-print check or using code tailored to the trusted 
module, the new device (i.e. a smart card, if changing a 
licence to another person; the internal trusted module, 
if changing a licence to another machine) should be re- 
registered with the vendor, and another key or tailored 
software issued based on the new device ID obtained 
respectively. 

[0056] For methods involving encryption and an un- 
lock key, if there is one smart card per application, the 
appropriate smart card (and any pins) should be given 
to the new licensee. Otherwise, the unlock key and data 
can be transferred between trusted modules automati- 
cally, without the need for the vendor to be involved be- 
yond receiving a report of the transfer (as described in 
the eighth method). This involves integrity checking of 
associated data, copying a licence key from one trusted 
module to another, and deinstalling the licence from the 
original trusted module. 

[0057] The stages in transferring a licence (i.e. unlock 
key L) for data S from TC1 in client machine Ml to TC2 
in machine M2 are, for example, as follows: 

A. Secure key transfer code ('SKT') is integrity 
checked as an extension of the BIS procedure. The 
licence transfer code is hashed and signed with the 
manufacturer's private key. Upon boot/installation 
of the platform, the package is verified by hashing, 
and comparison with the decrypted signature to 
check integrity, using a public key certificate in- 
stalled into the trusted module by the manufacturer. 
The licence transfer code will not be loaded if the 
digital signature does not match what is expected, 
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and the platform integrity check will fail. 

B. Initialisation. The content provider already has 
the public key of TC1 via the original registration 
and data installation process; if not, this is sent to 5 
him. 

1. If the owner of TC1 wishes to transfer the 
licence to TC2, there is a call from the OS of 
machine M1 to the SKT within M1 to transfer io 
the licence for data S to TC2. 

2. SKT in M1 generates a random number R 
and sends a message to M2 asking for the li- 
cence to be transferred, containing a reference ?5 
to the data S, together with the public key cer- 
tificate of TC1. 




key. The SKT in M1 sends this message to the SKT 
in M2, together with the symmetric key encrypted 
with TC2's public key and also a hash of all this in- 
formation, signed with TC1's private key. Only TC2 
will have the RSA private key to decrypt the sym- 
metric key, which will allow decryption of the unlock 
key. 

F. Message verification. The SKT in M2 checks the 
signature using the public key of TC1 , and decrypts 
the message using the symmetric key obtained by 
decryption using TC2's private key, thus obtaining 
the unlock key. If the signature is correct, the key is 
stored within the trusted component, and associat- 
ed with the data S. If the signature is not correct, an 
error message is sent to the SKT in M1 and the pro- 
tocol stops. 



3. If M2 obtains authorisation from an appropri- 
ate source, SKT in M2 replies in the affirmative, 20 
including R, the public key certificate of TC2, a 
reference to S, and a new nonce T that it has 
generated. 

4. SKT in M1 then sends to M2 the public key 25 
certificate of the content provider of S, together 
with T. 

These communications are appended to a hashed 
version of the communication signed by the trusted 30 
module's private key in the sender's machine, so 
that the receiver SKT can check the integrity of the 
message. If the integrity checks fail, messages are 
sent by each SKT to the OS within their machines 
and the protocol stops. 35 

C. Program upload. If the above authentication is 
successful, TC1 hashes the data S (optionally aver- 
sion already signed by the content provider) and 
signs it with the private key of TC1 (for example, 40 
using Microsoft's Authenticode). TC1 then uploads 
this signature together with the data into TC2. Op- 
tionally, the data is encrypted. 

D. Code verification. The secure loader within TC2 45 
verifies the signatures of the data S: it checks the 
signature using TC1's public key, thereby retrieving 

the message hash; next it computes the hash of S 
to check that it is the same as the decrypted mes- 
sage hash. If this validation is successful, the se- so 
cure loader installs the program into the machine 
corresponding to TC2. If not, it generates an error 
message to the SKT which blocks further passage 
of the licence transfer protocol. 

55 

E. Transfer key. The SKT in M1 generates a sym- 
metric key using a random number generator, and 
uses it to encrypt a message transporting the unlock 



G. Key deleted from TC1, and content provider no- 
tified. The SKT in M1 deletes the unlock key from 
TC1 and makes a log of this in TC1 . The SKT in M1 
sends a message to the content provider, signed 
using the private key of TC1 , informing the content 
provider that the licence for code S has been trans- 
ferred to M2. Optionally, SKT in M1 or in M2 sends 
a message to the data vendor giving details of how 
the owner of M2 may be contacted for registration. 

[0058] There is an option for the trusted component, 
and the software executor, to act as a new part of the 
operating system, and form a bridge between the oper- 
ating system and applications, by providing an environ- 
ment for certain functions. For example, API calls can 
be made to the trusted module such as 'save' and 're- 
store'. 'Save' will pass data through the trusted module, 
which will encrypt the data in the trusted module and 
store it either in the trusted module or on the hard disk. 
It will not be possible to access this data without the per- 
mission of the trusted module. There is an additional op- 
tion to carry out some transformations within the trusted 
module using such data, and for the software to use API 
calls to request information from the trusted module and 
get an answer exported. In summary, API calls can be 
used from the software executor or application code to 
the trusted module to check the presence of the trusted 
module or a private application key stored on the trusted 
module (analogous to existing dongle methods), and 
further, to use the trusted module for providing an envi- 
ronment for certain functions or data storage. 
[0059] More specifically, API calls may be added to 
the application code or the software executor and used 
to query the OS, trusted module or secure executor via 
the client library. For example, API calls may be added 
to the application code or the software executor and 
used to query the trusted module or secure executor via 
the client library to check for the presence of a private 
application key or other secret in the trusted module or 
smart card or to check for the identity and presence of 



SDOCID: <EP 1076279A1 _l_> 



8 




the trusted module or smart card. 

• [0060] In one particular model which will be described 
• in more detail later, a licensing model is employed in 
which an entry in a licensing-related database corre- 
sponding to the trusted module's ID is updated, and the 
secure executor will only allow data to run once permis- 
sions on this database have been checked. In this case, 
the software executor associated with an application 
calls the secure executor (possibly in the trusted mod- 
ule), the secure executor checks the licensing rights, 
and if this check succeeds, passes the call to the oper- 
ating system ('OS') in order for the application to be run 
in the normal manner. In other words, the OS accepts 
calls to execute data only if the call comes from secure 
licence-related code such as the secure executor or 
software executor. 

[0061] In another particular model which will be de- 
scribed in more detail later, the trusted module prefera- 
bly stores hardware and/or software used to implement 
the invention and the OS accepts calls to execute data 
if the call comes from the trusted module. In particular, 
the trusted module preferably acts as a bridge between 
an application and the OS and the OS preferably ignores 
all requests to load applications except for those from 
the trusted module. 

[0062] One possible licensing model would be for the 
secure executor to check in a database against the trust- 
ed module ID entry for an unlock key for the data. In this 
case the data is protected via encryption or partial en- 
cryption using the corresponding key, and hence can be 
freely distributed without fear of piracy. Once payment 
is made, the database entry corresponding to the trust- 
ed module's ID will be updated with this key. When the 
user wishes to run the application, the key can be re- 
trieved to allow the data to be unlocked: The key may 
then be stored in the tamper-proof device so that the 
database look-up need only happen once. However, in 
licensing models where floating licences are desired, it 
would be more appropriate to store such keys centrally 
and allow access only on each execution, so that the 
licence can then be restored to the appropriate group 
for use by another user. Thus, a model for licence "ex- 
change" is provided. 

[0063] Accordingly, the present invention extends to 
the case in which there is optional interaction between 
the secure executor, the software executor and the trust- 
ed module to use floating licences for a group of users 
via the secure executor or software executor instigating 
a check in a database against the trusted module ID en- 
try for a licence key for the software, retrieving a licence 
key (if one were available) in order to allow that partic- 
ular execution, and returning the licence key to the pool 
when the application is closed. 

[0064] In order to accommodate more flexible situa- 
tions such as hot-desking, when a variety of users use 
generic terminals, a combination of multiple trusted de- 
vices can be used. In particular, a combination of fixed 
tamper-proof components and portable tamper-proof 



components gives great flexibility in licensing. Most ob- 
viously, a personal user's smart card would be used in 
combination with an internal tamper-proof device within 
the computer. On this type of licensing model, the soft- 
s ware executor or secure executor would run the data 
only if a particular smart card is present (or one of a se- 
lected group of smart cards is present). 
[0065] The internal trusted module contains a trusted 
machine identity, and the portable trusted module (in 
io this case, a smart card) contains an identity specific to 
the user (which could be authenticated using an incor- 
porated biometric device). Many different ways of li- 
censing could be used in such a situation (one example 
is given in the following section), and these are analo- 
gs gous to the options presented in the 'Preferred Embod- 
iment' section. The differences are that, according to the 
particular model implemented: 

• The smart card identity is involved in the licensing 
20 check carried out by the secure executor or soft- 
ware executor, rather than the internal machine 
identity. Hence, for example, the user identity is 
checked against the profile or directory rather than 
the machine identity. In the case of unlock keys be- 

25 ing stored on the smart card, the presence of the 

smart card ID within the trusted module will cause 
the secure executor when requiring the unlock key 
to (a) copy the unlock key in an encrypted form to 
the trusted module, by the smart card encrypting it 

30 using the trusted module's public key, or (b) use the 

unlock key from the smart card directly. 

• There is authentication between the internal trusted 
module and the smart card. Authentication between 

35 the smart card and trusted module is carried out at 
the stage at which the smart card is inserted, and 
the current smart card ID is temporarily stored with- 
in the trusted module, to be used for the licensing 
check in the same way as the trusted module ID 

40 would have been used in the licensing models de- 
scribed in this document (see Examples A, B and F 
described later). When the smart card is removed, 
or (with single sign on) the user logs out, this tem- 
porary smart card ID value within the trusted mod- 

45 ule is reset to a null value. 

[0066] Both user-based licensing and machine-based 
licensing could be used for different data within the 
same machine. This could be done by (a) checking di- 

50 rectory entries against the smart card ID rather than the 
machine ID if the smart card ID value within the trusted 
module is not null (and against the machine ID if this 
fails), or (b) checking for an unlock key within the smart 
card if a smart card is currently inserted in the reader - 

55 that is to say, either requesting this to be copied to the 
trusted module, or using it directly. 
[0067] Accordingly, the invention extends to the case 
in which there is optional use of a combination of an in- 
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ternal machine trusted module and a portable trusted 
module (and the secure executor and software execu- 
tor) to perform licence checking based on the user iden- 
tity associated with the portable trusted module. 
[0068] A licensing system of the present invention s 
which will be described in more detail below, has the 
following features: 

• the computer platform is registered with athird party 

C. Optionally, C is given the trusted module ID or to 
smart card ID; 

• authentication between the trusted module and C 
and exchange of public key certificates takes place 
before, or at the same time as, exchange of DES is 
session keys for confidentiality of the messages; 

• the secure loader performs an integrity check on the 
data, and only installs the data if this succeeds; 

20 

• the data is executed using one of the protocols de- 
scribed above; and 

• each developer can use either generic or specific 
content protection. 25 

[0069] In one form: 

• data encrypted using a key K is signed under C's 
private code signing key and sent by C to the trusted 30 
module; 

• the unlock key corresponding to K is encrypted by 
C using the trusted module's public key, signed us- 
ing C's private code signing key, and sent to the 35 
computer platform; and 

• the key transfer code decrypts the unlock key, 
checks integrity and the signature, and this key is 
then stored in the trusted module, associated with 40 
the relevant data. 

[0070] In another form: 

• data encrypted using a key K is signed under C's 45 
private code signing key and sent by C to the trusted 
module; 

• an unlock key is transferred from C to the end-user 

of the computer platform or to the computer plat- 50 
form; 

• the key transfer code calculates the decryption key 
corresponding to K from the unlock key, the trusted 
module or smart card ID and a pre-stored algorithm; 55 

• optionally, the previous stage is carried out by the 
secure executor or software executor associated 



with the data; and 

• this decryption key is then stored in the trusted mod- 
ule or a smart card, associated with the relevant da- 
ta. 

[0071] In a further form: 

• data encrypted using a key K and any associated 
software executor is signed under C's private code 
signing key and sent by C to the trusted module; and 

• the unlock key corresponding to K is inserted into 
the database entry corresponding to the trusted 
module ID or smart card ID. 

[0072] In yet another form: 

• data and any associated software executor is 
signed under C's private code signing key and sent 
by C to the trusted module; and 

• an entry corresponding to permission to execute the 
data is inserted into the database entry correspond- 
ing to the trusted module ID or smart card ID, or vice 
versa. 

[0073] A specific embodiment of the present invention 
will now be described, purely by way of example, with 
reference to the accompanying drawings, in which: 

Figure 1 is a diagram which shows the 

motherboard of computing appa- 
ratus adapted to include a trusted 
device and as described in the pri- 
or patent application mentioned 
above; 

Figure 2 is a diagram which shows in more 

detail the trusted device shown in 
Figure 1; 

Figure 3 is a diagram which shows in the 

contents of a certificate stored in 
the trusted device; 

Figure 4 is a diagram, which showsthe fea- 

tures of a measurement function 
responsible for acquiring an integ- 
rity metric; 

Figure 5 is a flow diagram which illustrates 

the steps involved in acquiring an 
integrity metric of the computing 
apparatus; 

Figure 6 is a flow diagram which illustrates 

the steps involved in establishing 
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Figure 7 



communications between a trust- 
ed computing platform and a re- 
mote platform including the trust- 
ed platform verifying its integrity; 

5 

is a schematic block diagram of a 
host computer system which is the 
subject of another patent applica- 
tion (applicant's ref: 30990088) 
having the same filing date as the 10 
present application; 

is a schematic block diagram of a 
trusted module in the system of 
Figure 7; is 

show parts of the system ot Figure 
7 to illustrate various communica- 
tion methods employed therein; 

20 

illustrates the format of a protocol 
data unit used in the system of Fig- 
ure 7; 

shows a modification to the sys- 25 
tern of Figure 7, which will be used 
to describe a specific embodiment 
of the present invention; 

is a diagram of the logical compo- 30 
nents of a trusted module in the 
system of Figure .14; 

illustrates the structure of protect- 
ed software of data in the system 35 
of Figure 14; 

is a flow chart illustrating installing 
or upgrading software or other da- 
ta on the system of Figure 14; 40 

is a flow chart illustrating the use 
of protected software or data in the 
system of Figure 14 employing 
one model of licence checking; 45 

is a flow chart illustrating the use 
of protected software or data in the 
system of Figure 1 4 employing an- 
other model of licence checking; so 
and 

is a flow chart illustrating the use 
of protected software or data in the 
system of Figure 14 employing a 55 
further model of licence checking. 



[0074] Before describing the embodiment of the 
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present invention, the computing platform incorporating 
a trusted device which is the subject of the prior patent 
application mentioned above will firstly be described 
with reference to Figures 1 to 6. 

[0075] That application describes the incorporation 
into a computing platform of a physical trusted device 
or module whose function is to bind the identity of the 
platform to reliably measured data that provides an in- 
tegrity metric of the platform. The identity and the integ- 
rity metric are compared with expected values provided 
by a trusted party (TP) that is prepared to vouch for the 
trustworthiness of the platform. If there is a match, the 
implication is that at least part of the platform is operat- 
ing correctly, depending on the scope of the integrity 
metric. 

[0076] A user verifies the correct operation of the plat- 
form before exchanging other data with the platform. A 
user does this by requesting the trusted device to pro- 
vide its identity and an integrity metric. (Optionally the 
trusted device will refuse to provide evidence of identity 
if it itself was unable to verify correct operation of the 
platform.) The user receives the proof of identity and the 
integrity metric, and compares them against values 
which it believes to be true. Those proper values are" 
provided by the TP or another entity that is trusted by 
the user. If data reported by the trusted device is the 
same as that provided by the TP, the user trusts the plat- 
form. This is because the user trusts the entity. The en- 
tity trusts the platform because it has previously validat- 
ed the identity and determined the proper integrity met- 
ric of the platform. 

[0077] Once a user has established trusted operation 
of the platform, he exchanges other data with the plat- 
form. For a local user, the exchange might be by inter-; 
acting with some software application running on the 
platform. For a remote user, the exchange might involve 
a secure transaction. In either case, the data exchanged 
is 'signed' by the trusted device: The user can then have 
greater confidence that data is being exchanged with a 
platform whose behaviour can be trusted. 
[0078] The trusted device uses cryptographic proc- 
esses but does not necessarily provide an external in- 
terface to those cryptographic processes. Also : a most 
desirable implementation would be to make the trusted 
device tamperproof, to protect secrets by making them 
inaccessible to other platform functions and provide an 
environment that is substantially immune to unauthor- 
ised modification. Since tamper-proofing is impossible, 
the best approximation is a trusted device that is tamper- 
resistant, or tamper-detecting. The trusted device, 
therefore, preferably consists of one physical compo- 
nent that is tamper-resistant. 

[0079] Techniques relevant to tamper-resistance are 
well known to those skilled in the art of security. These 
techniques include methods for resisting tampering, 
methods for detecting tampering, and methods for elim- 
inating data when tampering is detected. It will be ap- 
preciated that, although tamper-proofing is a most de- 
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sirable feature of the present invention, it does not enter 
into the normal operation of the invention and, as such, 
is beyond the scope of the present invention and will not 
be described in any detail herein. 
[0080] The trusted device is preferably a physical one 
because it must be difficult to torge. It is most preferably 
tamper-resistant because it must be hard to counterfeit. 
It typically has an engine capable of using cryptographic 
processes because it is required to prove identity, both 
locally and at a distance, and it contains at least one 
method of measuring some integrity metric of the plat- 
form with which it is associated. 

[0081] Figure 1 illustrates the motherboard 10 of an 
exemplary computer platform (not shown). The mother- 
board 10 includes (among other standard components) 
a main processor 1 1 . main memory 1 2, a trusted device 
14, a data bus 16 and respective standard control lines 
1 7 and address lines 1 8, and BIOS memory 1 9 contain- 
ing the BIOS program for the platform. 
[0082] Typically, the BIOS program is located in a spe- 
cial reserved memory area, the upper 64K of the first 
megabyte do the system memory (addresses F000h 
to FFFFh), and the main processor is arranged to look 
at this memory location first, in accordance with an in- 
dustry wide standard. 

[0083] The significant difference between the plat- 
form and a conventional platform is that, after reset, the 
main processor is initially controlled by the trusted de- 
vice, which then hands control over to the platform-spe- 
cific BIOS program, which in turn initialises all input/out- 
put devices as normal. After the BIOS program has ex- 
ecuted, control is handed over as normal by the BIOS 
program to an operating system program, such as Win- 
dows NT (TM), which is typically loaded into main mem- 
ory 12 from a hard disk drive (not shown). 
[0084] Clearly, this change from the normal procedure 
requires a modification to the implementation of the in- 
dustry standard, whereby the main processor 11 is di- 
rected to address the trusted device 1 4 to receive its first 
instructions. This change may be made simply by hard- 
coding a different address into the main processor 11. 
Alternatively, the trusted device 1 4 may be assigned the 
standard BIOS program address, in which case there is 
no need to modify the main processor configuration. 
[0085] Although, the trusted device 14 is a described 
as a single, discrete component, it is envisaged that the 
functions of the trusted device 14 may alternatively be 
split into multiple devices on the motherboard, or even 
integrated into one or more of the existing standard de- 
vices of the platform. For example, it is feasible to inte- 
grate one or more of the functions of the trusted device 
into the main processor itself, provided that the functions 
and their communications cannot be subverted. This, 
however, would probably require separate leads on the 
processor for sole use by the trusted functions. Addi- 
tionally or alternatively, although the trusted device is 
described as a hardware device that is adapted for in- 
tegration into the motherboard 10, it is anticipated that 



a trusted device may be implemented as a 'removable' 
device, such as a dongle, which could be attached to a 
platform when required. Whether the trusted device is 
integrated or removable is a matter of design choice. 

5 [0086] The trusted device 14 comprises a number of 
blocks, as illustrated in Figure 2: a controller 20 for con- 
trolling the overall operation of the trusted device 14, 
and interacting with the other functions on the trusted 
device 14 and with the other devices on the mother- 

10 board 10; a measurement function 21 for acquiring an 
integrity metric from the platform; a cryptographic func- 
tion 22 for signing or encrypting specified data; and in- 
terface circuitry 23 having appropriate ports (24, 25 & 
26) for connecting the trusted device 1 4 respectively to 

15 the data bus 16, control lines 17 and address lines 18 
of the motherboard 10. Each of the blocks in the trusted 
device 14 has access (typically via the controller 20) to 
appropriate volatile memory areas 27 and/or non-vola- 
tile memory areas 28 of the trusted device 14. 

20 [0087] For reasons of performance, the trusted device 
14 may be implemented as an application specific inte- 
grated circuit (ASIC). However, for flexibility, the trusted 
device is preferably an appropriately programmed mi- 
cro-controller Both ASICs and micro-controllers are 

25 well known in the art of microelectronics and will not be 
considered herein in any further detail. 
[0088] One item of data stored in the non-volatile 
memory is a certificate 30, which is illustrated in Figure 
3 The certificate 30 contains at least a public key 32 of 

30 the trusted device 14 and an authenticated value of a 
platform integrity metric 34 measured by a TP. Option- 
ally, the trusted device 14 also contains an identity (ID) 
label 36 of the trusted device 14. 

[0089] Where present, the ID label 36 is a convention- 
's al ID label, for example a serial number, that is unique 
within some context. The ID label 36 is generally used 
for indexing and labelling of data relevant to the trusted 
device 14, but is insufficient in itself to prove the identity 
of the platform under trusted conditions. 
40 [0090] The trusted device 1 4 is equipped with at least 
one method of reliably measuring some integrity metric 
of the computing platform with which it is associated. 
The integrity metric is acquired by the measurement 
function 21 , which is illustrated in more detail in Figure 4. 
45 [0091] The measurement function 21 has access to 
non-volatile memory 40 for storing a hash program 41 , 
plus volatile memory 42 for storing a computed integrity 
metric 43, in the form of a digest. The hash program 41 
contains instructions for computing the digest, in code 
so that is native to the main processor 11 . In addition, part 
of the measurement function 21 is configured to respond 
to the main processor 11 as if it were addressable mem- 
ory, such as standard read-only memory, by sensing 
memory read signals addressed to the trusted device 
55 1 4 and returning appropriate data. The result is that the 
main processor 11 sees the trusted device, for the pur- 
poses of integrity metric measurement, as a standard 
read-only memory 



12 



DOCID: <EP 1076279A1_L> 




[0092] In the preferred implementation, as well as the 
digest, the integrity metric includes a Boolean value 44, 
which is stored in volatile memory 45 by the measure- 
ment function 21 , for reasons that will become apparent. 
[0093] A preferred process for acquiring an integrity 
metric will now be described with reference to Figure 5. 
[0094] In step 500, at switch-on, the measurement 
function 21 monitors the activity of the main processor 
11 on the data, control and address lines (16, 17 & 18) 
to determine whether the trusted device 14 is the first 
memory accessed. Under conventional operation, a 
main processor would first be directed to the BIOS mem- 
ory first in order to execute the BIOS program. However, 
in accordance with the present embodiment, the main 
processor 11 is directed to the trusted device 14, which 
acts as a memory. In step 505, if the trusted device 14 
is the first memory accessed, in step 510, the measure- 
ment function 21 writes to volatile memory 45 a Boolean 
value 44, which indicates that the trusted device 1 4 was 
the first memory accessed. Otherwise, in step 515, the 
measurement function writes a Boolean value 44, which 
indicates that the trusted device 14 was not the first 
memory accessed. 

[0095] In the event the trusted device 1 4 is not the first 
accessed, there is of course a chance that the trusted 
device 14 will not be accessed at all. This would be the 
case, for example, if the main processor 11 were ma- 
nipulated to run the BIOS program first. Under these cir- 
cumstances, the platform would operate, but would be 
unable to verify its integrity on demand, since the integ- 
rity metric would not be available. Further, if the trusted 
device 14 were accessed after the BIOS program had 
been accessed, the Boolean value 44 would clearly in- 
dicate lack of integrity of the platform. 
[0096] In step 520, when (or if) accessed as a memory 
by the main processor 11, the main processor 11 reads 
the stored native hash instructions 41 from the meas- 
urement function 21 in step 525. The hash instructions 
41 are passed for processing by the main processor 11 
over the data bus 16. In step 530, main processor 11 
executes the hash instructions 41 and uses them, in 
step 535, to compute a digest of the BIOS memory 19, 
by reading the contents of the BIOS memory 19 and 
processing those contents according to the hash pro- 
gram. In step 540, the main processor 11 writes the com- 
puted digest 43 to the appropriate non-volatile memory 
location 42 in the trusted device 14. The measurement 
function 21 , in step 545, then calls the BIOS program in 
the BIOS memory 1 9,' and execution continues in a con- 
ventional manner. 

[0097] Clearly, there are a number of different ways 
in which the integrity metric may be calculated, depend- 
ing upon the scope of the trust required. The measure- 
ment of the BIOS program's integrity provides a funda- 
mental check on the integrity of a platform's underlying 
processing environment. Other integrity checks could 
involve establishing that various other devices, compo- 
nents or apparatus attached to the platform are present 



and in correct working order. In one example, the BIOS 
programs associated with a SCSI controller could be 
verified to ensure communications with peripheral 
equipment could be trusted. In another example, the in- 

5 tegrity of other devices, for example memory devices or 
co-processors, on the platform could be verified by en- 
acting fixed challenge/response interactions to ensure 
consistent results. Also, although in the present embod- 
iment the trusted device 14 utilises the data bus as its 

to main means of communication with other parts of the 
platform, it would be feasible, although not so conven- 
ient, to provide alternative communications paths, such 
as hard-wired paths or optical paths. Further, although 
in the present embodiment the trusted device 14 in- 

is structs the main processor 11 to calculate the integrity 
metric, it is anticipated that, in other embodiments, the 
trusted device itself will be arranged to measure one or 
more integrity metrics. 

[0098] Preferably, the BIOS boot process includes 

20 mechanisms to verify the integrity of the boot process 
itself. Such mechanisms are already known from, for ex- 
ample, Intel's draft "Wired for Management baseline 
specification v 2.0 - BOOT Integrity Service", and in- ■'■ 
volve calculating digests of software or firmware before- 

2S loading that software or firmware. Such a computed di- 
gest is compared with a value stored in a certificate pro- 
vided by a trusted entity, whose public key is known to* 
the BIOS. The software/firmware is then loaded only if 
the computed value matches the expected value from 

30 the certificate, and the certificate has been proven valid 
by use of the trusted entity's public key Otherwise, an 
appropriate exception handling routine is invoked. 
[0099] Optionally, after receiving the computed BIOS 
digest, the trusted device 1 4 may inspect the proper val-" 

35 ue of the BIOS digest in the certificate and not pass con- 
trol to the BIOS if the computed digest does not match 
the proper value. Additionally, or alternatively, the trust- 
ed device 14 may inspect the Boolean value 44 and not 
pass control back to the BIOS if the trusted device 14 

40 was not the first memory accessed. 

[0100] Figure 6 illustrates the flow of actions by a TP, 
the trusted device 14 incorporated into a platform : and 
a user (of a remote platform) who wants to verify the 
integrity of the trusted platform. It will be appreciated 

45 that substantially the same steps as are depicted in Fig- 
ure 6 are involved when the user is a local user. In either 
case, the user would typically rely on some form of soft- 
ware application to enact the verification. It would be 
possible to run the software application on the remote 

so platform or the trusted platform. However, there is a 
chance that, even on the remote platform, the software 
application could be subverted in some way. Therefore, 
it is anticipated that, for a high level of integrity, the soft- 
ware application would reside on a smart card of the us- 

55 er, who would insert the smart card into an appropriate 
reader for the purposes of verification. 
[0101] At the first instance, a TP, which vouches for 
trusted platforms, will inspect the type of the platform to 
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decide whether to vouch for it or not. This will be a matter 
of policy. If all is well, in step 600, the TP measures the 
value of integrity metric of the platform. Then, the TP 
generates a certificate, in step 605, for the platform. The 
certificate is generated by the TP by appending the trust- 5 
ed device's public key, and optionally its ID label, to the 
measured integrity metric, and signing the string with the 
TP's private key. 

[01 02] The trusted device 1 4 can subsequently prove 
its identity by using its private key to process some input 10 
data received from the user and produce output data, 
such that the input/output pair is statistically impossible 
to produce without knowledge of the private key. Hence, 
knowledge of the private key forms the basis of identity 
in this case. Clearly, it would be feasible to use symmet- is 
ric encryption to form the basis of identity. However, the 
disadvantage of using symmetric encryption is that the 
user would need to share his secret with the trusted de- 
vice. Further, as a result of the need to share the secret 
with the user, while symmetric encryption would in prin- 20 
ciple be sufficient to prove identity to the user, it would 
insufficient to prove identity to a third party, who could 
not be entirely sure the verification originated from the 
trusted device or the user. 

[0103] In step 610, the trusted device 14 is initialised 25 
by writing the certificate 30 into the appropriate non-vol- 
atile memory locations of the trusted device 14. This is 
done, preferably, by secure communication with the 
trusted device 14 after it is installed in the motherboard 
10. The method of writing the certificate to the trusted 30 
device 14 is analogous to the method used to initialise 
smart cards by writing private keys thereto. The secure 
communications is supported by a 'master key', known 
only to the TP, that is written to the trusted device (or 
smart card) during manufacture, and used to enable the 35 
writing of data to the trusted device 14; writing of data 
to the trusted device 1 4 without knowledge of the master 
key is not possible. 

[01 04] At some later point during operation of the plat- 
form, for example when it is switched on or reset, in step 40 
615, the trusted device 14 acquires and stores the in- 
tegrity metric 43 of the platform. 

[0105] When a user wishes to communicate with the 
platform, in step 620 : he creates a nonce, such as a ran- 
dom number, and, in step 625, challenges the trusted 45 
device 14 (the operating system of the platform, or an 
appropriate software application, is arranged to recog- 
nise the challenge and pass it to the trusted device 14, 
typically via a BIOS-type call, in an appropriate fashion). 
The nonce is used to protect the user from deception so 
caused by replay of old but genuine signatures (called 
a 'replay attack') by untrustworthy platforms. The proc- 
ess of providing a nonce and verifying the response is 
an example of the well-known 'challenge/response 1 
process 55 
[0106] In step 630, the trusted device 14 receives the 
challenge and creates a digest of the measured integrity 
metric and the nonce, and optionally its ID label. Then, 
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in step 635, the trusted device 1 4 signs the digest, using 
its private key, and returns the signed digest, accompa- 
nied by the certificate 30, to the user. 
[0107] In step 640, the user receives the challenge re- 
sponse and verifies the certificate using the well known 
public key of the TP. The user then, in step 650, extracts 
the trusted device's 14 public key from the certificate 
and uses it to decrypt the signed digest from the chal- 
lenge response. Then, in step 660, the user verifies the 
nonce inside the challenge response. Next, in step 670, 
the user compares the computed integrity metric, which 
it extracts from the challenge response, with the proper 
platform integrity metric, which it extracts from the cer- 
tificate. If any of the foregoing verification steps fails, in 
steps 645, 655, 665 or 675, the whole process ends in 
step 680 with no further communications taking place. 
[0108] Assuming all is well, in steps 685 and 690, the 
user and the trusted platform use other protocols to set 
up secure communications for other data, where the da- 
ta from the platform is preferably signed by the trusted 
device 14. 

[0109] The techniques of signing, using certificates, 
and challenge/response, and using them to prove iden- 
tity, are well known to those skilled in the art of security 
and will, thus, not be described in any more detail herein. 
[0110] Referring now to Figures 7 to 1 3, a specific em- 
bodiment of the invention which is the subject of the oth- 
er patent application, mentioned above, having the 
same filing date as the present application will now be 
described In Figure 7, a host computer 100 has a main 
CPU 1 02, a hard disk drive 1 04, a PCI network interface 
card 106 and DRAM memory 108 with conventional 
("normal") communications paths 110 (such as ISA, EI- 
SA, PCI, USB) therebetween. The network interface 
card 106 also has an external communication path 112 
with the world outside the host computer 100. 
[0111] The network interface card 106 is logically di- 
vided into "red" and "black" data zones 114,116 with an 
interface 118 therebetween. In the red zone 114, data 
is usually plain text and is sensitive and vulnerable to 
undetectable alteration and undesired eavesdropping. 
In the black data zone 116, data is protected from un- 
detected alteration and undesired eavesdropping (pref- 
erably encrypted by standard crypto mechanisms). The 
interface 118 ensures that red information does not leak 
into the black zone 116. The interface 118 preferably us- 
es standard crypto methods and electronic isolation 
techniques to separate the red and black zones 1 1 4, 1 1 6. 
The design and construction of such red and black 
zones 114,116 and the interface 118 is well known to 
those skilled in the art of security and electronics, par- 
ticularly in the military field. The normal communication 
path 110 and external communication path 112 connect 
with the black zone 116 of the network interface card 
106. 

[0112] The host computer 100 also includes a trusted 
module 120 which is connected, not only to the normal 
communication paths 1 1 0, but also by mutually separate 
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additional communication paths 122 (sub-referenced 
122a. 122b. 122c) to the CPU 102. hard disk drive 104 
f and the red zone 114 of the network interface card 106. 
By way of example, the trusted module 120 does not 
have such a separate additional communication path 
122 with the memory 108. 

[01 1 3] The trusted module 1 20 can communicate with 
the CPU 102, hard disk drive 104 and red zone 114 of 
the network interface card 1 06 via the additional com- 
munication paths 122a,b,c, respectively. It can also 
communicate with the CPU 102, hard disk drive 104, 
black zone 116 of the network interface card 106 and 
the memory 108 via the normal communication paths 
110. The trusted module 120 can also act as a 100VG 
switching centre to route certain information between 
the CPU 1 02, hard disk drive 1 04 and the red zone 1 1 4 
of the network interface card 106, wathe trusted module 
1 20 and the additional communication paths 1 22, under 
control of a policy stored in the trusted module. The 
trusted module 120 can also generate cryptographic 
keys and distribute those keys to the CPU 102, the hard 
disk drive 104, and the red zone 114 of the network in- 
terface card 1 06 via the additional communication paths 
122a,b,c, respectively. 

[0114] Figure 8 illustrates the physical architecture of 
the trusted module 120. A first switching engine 124 is 
connected separately to the additional communication 
paths 122a,b,c and also to an internal communication 
path 126 of the trusted module 120. This switching en- 
gine 1 24 is under control of a policy loaded into the trust- 
ed module 120. Other components of the trusted mod- 
ule 120 are: 

• a computing engine 128 that manages the trusted 
module 1 20 and performs general purpose comput- 
ing for the trusted module 1 20; 

• volatile memory 1 30 that stores temporary data; 

• non-volatile memory 1 32 that stores long term data; 

• cryptographic engines 134 that perform specialist 
crypto functions such as encryption and key gener- 
ation; 

• a random number source 1 36 used primarily in cryp- 
to operations; 

• a second switching engine 138 that connects the 
trusted module 120 to the normal communication 
paths 110; and 

• tamper detection mechanisms 140, 

all connected to the internal communication path 1 26 of 
the trusted module 120. 

[0115] The trusted module 120 is based on a trusted 
device or module 14 as described in more detail above 
with reference to Figures 1 to 6. 

[0116] With regard to crypto key generation and dis- 
tribution, the trusted module 120 generates crypto- 
graphic keys, using the random number generator 136, 
a hash algorithm, and other algorithms, all of which are 
well known, perse, to those skilled in the art of security. 



The trusted module 1 20 distributes selected keys to the 
CPU 102, hard disk drive 104 and the red zone 114 of 
the network interface card 1 05 using the additional com- 
munication paths 122a,b,c, respectively, rather than the 
s normal communications paths 110. Keys may be used 
for communications between the internal modules 
102,104,106,120 of the platform over the normal com- 
munication paths 110. Other temporary keys may be 
used (by the network interface card 1 06 or CPU 1 02) for 

to bulk encryption or decryption of external data using the 
SSL protocol after the trusted module 1 20 has complet- 
ed the SSL handshaking phase that uses long term 
identity secrets that must not be revealed outside the 
trusted module 1 20. Other temporary keys may be used 

75 (by the hard disk drive 1 04 or CPU 1 02) for bulk encryp- 
tion or decryption of data stored on the hard disk drive 
104 after those temporary keys have been created or 
revealed inside the trusted module 1 20 using long term 
secrets that must not be revealed outside the trusted 

20 module 120. 

[0117] The trusted module 120 enforces policy control 
over communications between modules by the selective 
distribution of encryption keys. The trusted module 120 * 
enforces a policy ban on communications between giv- 

zs en pairs of modules by refusing to issue keys that enable 
secure communications over the shared infrastructure. 
110 between those pairs of modules. 
[0118] Figure 9 illustrates a process by which the 
trusted module 120 can perform a watchdog function 

30 and 'ping' the modules 102,104,106 connected to the 
additional communication paths 122. The trusted mod- 
ule generates a challenge 142 and sends it to the CPU 
102, hard disk drive 104 and red zone 11 4 of the network 
interface card 106 using the additional communication 

35 paths 122a,b,c, respectively. Each of the CPU 102, hard 
disk drive 104 and network interface card 106 responds 
with a response 144a,b,c, respectively, on the respec- 
tive additional communication path 122a,b,c to say 
whether the respective module is active, and preferably 

40 that the module is acting properly. The trusted module 
120 notes the responses 144a,b,c and uses them as 
metrics in its responses to integrity challenges that are 
described above with reference to Figures 1 to 6. 
[0119] Figure 10 illustrates the process by which in- 

45 coming external secure messages are processed when 
the trusted mod ule 1 20 is the only module in the platform 
with cryptographic capabilities. An external message 
146 is received by the black zone 116 of the network 
interface card 106 using the external communication 

50 path 112. The network interface card 106 sends a pro- 
tocol data unit 1 48 (to be described in further detail later) 
containing some data and a request for an authentica- 
tion and integrity check to the trusted module 1 20 using 
the normal communication paths 110. The trusted mod- 

55 ule 1 20 performs the authentication and integrity checks 
using the long term keys inside the trusted module 120 
that must not revealed outside the trusted module 120, 
and sends a protocol data unit 150 containing an 'OK 1 
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indication to the red zone 114 of the network interface 
card 1 06 using the additional communication path 1 22c. 
The network interface card 106 then sends a protocol 
data unit 152 containing some data and a request for 
decryption to the trusted module 120 using the normal s 
communication paths 110. The trusted module 120 de- 
crypts the data using either temporary or long term keys 
inside the trusted module 120, and sends a protocol da- 
ta unit 154 containing the decrypted data to the CPU 
1 02 using the additional communication path 1 22a. The 10 
CPU then takes appropriate action. 
[0120] Figure 11 illustrates the process by which the 
CPU 102 requests a policy decision from the trusted 
module 1 20. This could be used, for example, when the 
CPU 102 must determine whether policy allows certain is 
data to be manipulated or an application to be executed. 
This will be described in more later with reference to Fig- 
ures 14 to 20. The CPU 102 sends a protocol data unit 
156 containing a request to the trusted module 120 us- 
ing the normal communication paths 110. The trusted 20 
module 1 20 processes the request 1 56 according to the 
policy stored inside the trusted module 1 20. The trusted 
module 120 sends a protocol data unit 158 containing 
a reply to the CPU 102 using the additional communi- 
cation path 1 22a, in order that the CPU 1 02 can be sure 25 
that authorisation came from the trusted module 120. If 
the action is authorised, the CPU 102 takes the neces- 
sary action. Otherwise, it abandons the process. 
[01 21] Figure 1 2 illustrates an example of the control 
of policy over protected communications between the 30 
modules 102,104,106. All of the communications in this 
example use the additional communication paths 122. 
The red zone 114 of the network interface card 106 
sends a protocol data unit 160 that is destined for the 
hard disk drive 104 to the trusted module 120 on the 35 
additional data path 122c. In the case where the policy 
does not permit this, the trusted module 120 denies the 
request by sending a protocol data unit 162 containing 
a denial to the network interface card 106 on the addi- 
tional data path 1 22c. Later, the CPU 1 02 requests sen- 40 
sitive data from the hard disk drive 104 by sending a 
protocol data unit 164 addressed to the hard disk drive, 
but sent on the additional data path 122a to the trusted 
module 120. The trusted module 120 checks that the 
policy allows this. In the case where it does, the trusted 45 
module 1 20 relays the protocol data unit 1 64 to the hard 
disk drive 104 on the additional data path 122b. The 
hard disk drive 104 provides the data and sends it in a 
protocol data unit 166 on the additional data path 122b 
back to the trusted module 120 addressed to the CPU 50 
102. The trusted module 120 checks that the policy al- 
lows this, and, in the case where it does, relays the pro- 
tocol data unit 1 66 to the CPU 1 02 on the additional data 
path 122a. 

[01 22] Figure 1 3 illustrates the format of the data pro- 55 
tocol units 178 by which data is passed over the addi- 
tional communication paths 122. The data protocol unit 
178 has:- 
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• an identifier field 168 indicating the type of the pro- 
tocol data unit; 

• a length field 1 70 indicating the length of the proto- 
col data unit: 

• a source field 172 indicating the source of the pro- 
tocol data unit; 

• a destination field 174 indicating the destination of 
the protocol data unit; 

• and so on, including in many cases a data field 1 76. 

[0123] Not all fields are always necessary. For exam- 
ple, assuming the policy of the trusted module 120 for- 
bids it to relay key protocol data units that that did not 
originate within the trusted module 120, the CPU 102, 
hard disk drive 1 04 and network interface card 1 06 can 
therefore assume that keys are always from the trusted 
module 120. Hence, source and destination fields are 
unnecessary in key protocol data units - such protocol 
data units are implicitly authenticated. The design and 
construction and use, per se, of protocol data units is 
well known to those skilled in the art of communications. 
[0124] The specific embodiment of the present inven- 
tion will now be described with reference to Figures 14 
to 20. Figure 14 illustrates the physical system and is a 
development of the system described above with refer- 
ence to Figures 7 to 13. In Figure 14, a display 121 is 
connected to the trusted module 120 by means of one 
122d of the additional communications paths as de- 
scribed above. This enables the trusted module 120 to 
reliably write to the display, without fear of subversion 
from normal software, including the operating system. 
Also, the host computer 100 is connected to a keyboard 
101 that has a built-in smart card reader 103, both of 
which are connected to the normal communications 
paths 110. A smart card which is inserted into the smart 
card reader 103 can be considered to be an additional 
trusted module and is therefore able to communicate se- 
curely with the trusted module 120. 
[0125] Figure 15 illustrates a logical diagram of the 
components of the trusted module 120, comprising li- 
censing code components 200 and other licensing data 
components 202 within the trusted module 120. The li- 
censing code components 200 run within a protected 
environment, as previously described, and preferably 
within the trusted module 1 20 itself, and comprise: a se- 
cure executor 204, a secure loader 206, secure key- 
transfer code 208 and a client library 210. The licence- 
re laled data components 202 stored on the trusted mod- 
ule 1 20 include the private key 21 2 of the trusted module 
120, the public key certificate 214 of a trusted entity, the 
clearinghouse or developer's public key certificate 216, 
a licensing log 218, and a hashed version 220 of the 
licence-related code 200, signed with the private key of 
the trusted entity who has the public key certificate 214. 
[0126] Figure 16 illustrates the structure of protected 
software or data 222 within the client computer 100. Dig- 
ital data 224 on the client computer 100 is associated 
with a respective software executor 226, within which is 
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stored the public key 228 of the trusted module 1 20. This 
structure 230 is stored together with a hashed version 
232 of it, signed with the clearinghouse or developer's 
private key. There will be a structure analogous to the 
resulting unit 222 for each piece of protected software 5 
or data. 

[0127] Figure 17 illustrates the flowchart for loading 
or upgrading software or other data onto the client plat- 
form, for the general case where the secure loader 206 
may not be running within the trusted module 120. 10 
[0128] The data to be installed is hashed and signed 
with the sender's private key, and this is appended to 
the data itself by the sender. 

[0129] In step 234, the operating system sends a re- 
quest, together with the data and the signed hashed ver- 15 
sion, to the secure loader 206 that the data be installed. 
In step 236. the secure loader 206 receives the request, 
and in step 238 it checks the signature of this message, 
using the public key certificate corresponding to the 
sender, thereby checking authentication of the sender. 20 
[0130] If authentication fails, then in step 240 the se- 
cure loader 206 sends an error message to the operat- 
ing system. In step 242 the operating system receives 
this error message, and in step 244 displays an appro- 
priate message. 25 
[01 31] If authentication succeeds in step 238, then in 
step 246 the secure loader 206 computes the hash of 
the message, via the cryptographic capabilities availa- 
ble within the trusted module 120, and in step 248 com- 
pares it to the message hash that is associated with the 30 
data and was received in step 236. This checks for in- 
tegrity of the message. 

[0132] If the hashes are not the same, this indicates 
that the data has been altered, and that it should not be 
installed. In this case, in step 250 the secure loader 206 35 
sends an error message to the OS, which then performs 
steps 242,244 described above. 

[01 33] If the hashes are found to be the same in step 
248, then in step 252 the trusted module 120 makes a 
log of the installation, and in step 254 the secure loader 40 
206 indicates to the OS that the data can be installed as 
normal, which then happens in step 256. 
[0134] If other forms of check (particularly licence 
checks) are additionally or alternatively to be employed, 
these may be included between steps 250 and 252 in 45 
the method described with reference to Figure 17. 
[0135] Figure 18 illustrates the flowchart for licensing 
using a model of licence checking where the OS com- 
municates with the secure executor 204, and the soft- 
ware executor 226 associated with a piece of data has so 
the option to choose the licensing model to be used for 
protection of that data. This again is for the general case 
where licensing software is not necessarily mounted 
within the trusted module 120. The procedure is as fol- 
lows: 55 
[01 36] When the user wishes to run some digital data, 
in step 258 a request is sent by the operating system, 
which is received by the secure executor 204 in step 



260. In step 262, the secure executor 206 generates a 
random number (nonce), and in step 264 issues a chal- 
lenge/response to the software executor 226 corre- 
sponding to that piece of data, by means of sending the 
nonce, together with a reference to the application (e.g. 
its title), signed using the private key 21 2 of the trusted 
module 120. 

[0137] Following receipt in step 266 by the software 
executor 226, in step 268 it verifies and authenticates 
the secure executor's challenge using the public key 
228 of the trusted module 120. If there is an error, or if 
the software executor 226 does not wish the data to be 
executed on this particular machine, an error message 
is sent in step 270, which is relayed by the secure ex- 
ecutor 204 in step 272 to the operating system. Follow- 
ing receipt of such an error message in step 274, the 
operating system displays an appropriate error mes- 
sage in step 276 and the data is not executed. 
[01 38] If there is no error in step 268, then in step 278 
the software executor 226 returns a message to the se- 
cure executor 204 incorporating the nonce, the refer- 
ence to the data and optionally a licensing model. The 
nonce is included to give protection against replay at- 
tacks. 

[01 39] Having received the message in step 280, then 
in step 282 the secure executor 204 makes the appro- 
priate licensing check dependent upon the licensing 
model specified by the software executor. This may in- 
volve unlocking the data using a key. Further details of 
these licensing models are considered later. If there is 
no software executor associated with the data, the se- 
cure executor makes a licensing check corresponding 
to a default licensing model previously set within it by 
an administrator. If there is a valid licence, in step 284 
the secure executor 204 asks the trusted module 1 20 to 
takes a metering record of the transaction, steps 
286,288, and in step 290 sends permission to the oper- 
ating system to execute the data. Upon receipt in step 
292, the operating system executes the data in step 294. 
Following the licensing check in step 282, if there is no 
valid licence, in step 296 the secure executor 204 asks 
the operating system to notify the end-user appropriate- 
ly, steps 274,276, and the data is not executed. 
[0140] Figure 19 is a flowchart for licensing using a 
model of licence checking where the OS communicates 
with the software executors 226 rather than the secure 
executor 204. This again is for the general case where 
licensing software is not necessarily mounted within the 
trusted module 120. 

[0141] When the user wishes to execute some data, 
in step 298 the OS sends a message to the software 
executor 226 associated with the data, received in step 
300. In step 302, the software executor 226 generates 
a random number (nonce), and in step 304 issues a 
challenge/response to the secure executor 204 within 
the trusted module 1 20, by means of sending the nonce, 
together with a reference to the data. In addition, a smart 
card ID is sent, if that was used to log in to the client 
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machine and hot-desking is the licensing model to be 
used 

[0142] Following receipt in step 306 of the message, 
in step 308 the secure executor 204 makes an appro- 
priate licensing check on the data. If there is no valid 
licence, then in step 310 the secure executor 204 re- 
turns an error message, from which the software exec- 
utor could determine the exact type of problem with li- 
censing and notifies the OS appropriately, steps 
312,314,316. 

[0143] If there is a valid licence, then in step 318 the 
secure executor 204 returns a message incorporating 
the nonce and reference to the data, signed and en- 
crypted using the private key 212 of the trusted module 
120. The nonce is included to give protection against 
replay attacks. 

[0144] Following receipt in step 320 of the message, 
in step 322 the software executor 226 verifies if the se- 
cure executor's reply is correct using the public key cer- 
tificate 228 of the trusted module 1 20. If it is correct, then 
in step 324 the software executor 226 asks trusted mod- 
ule 120 makes a log, steps 326,328 and in step 330 
passes the call to the OS to execute the data, steps 
332,334. On the other hand, if it is not correct, in step 
336 the software executor 226 sends an error message 
to the OS, which then displays an error message as ap- 
propriate, steps 314,316. 

[01 45] In a preferred mechanism for enforcing checks 
on permission to execute digital data, the trusted mod- 
ule 120 includes the hardware and/or stores the soft- 
ware used to implement the invention. In particular, the 
trusted module 120 acts as a bridge between an appli- 
cation and the OS. The OS preferably ignores all re- 
quests to load or run applications except those from the 
trusted module 120, given via a communications path 
122 between the trusted module 120 and the CPU 102 
that is preferably inaccessible to ordinary applications 
and non-OS software. The processes operating on the 
host computer are as follows. First, there is an initial re- 
quest to the trusted module 120 to execute an applica- 
tion or other data, preferably via the software executor 
226 associated with this data, and usually in response 
to some action by the end-user. The software executor 
226 will contain the public key certificate 228 of the trust- 
ed module 120 on which the data is installed or to be 
installed. The secure executor 204 within the trusted 
module 120 will carry out appropriate licence checking, 
as detailed above. If the result of this checking is that it 
is appropriate to execute the data, the secure executor 
204 will convey this information to the OS via a commu- 
nications path 122 to the CPU 102, which is preferably 
inaccessible to ordinary applications and non-OS soft- 
ware. The OS then starts a process on the host to exe- 
cute the application or data. An analogous process will 
be carried out when the secure loader communicates 
with the OS to indicate that data installation is appropri- 
ate, or when the key transfer code communicates with 
the OS to transfer unlock keys. 



[0146] Figure 20 illustrates the flowchart for licensing 
using a model of licence checking as mentioned above, 
where licensing software is stored within the trusted 
module 120, and the trusted module 120 acts as a 

5 bridge between an application and the OS. The process 
is similar to that given in Figure 19, except that the se- 
cure executor 204 is within the trusted module 1 20 itself 
and the secure executor 120 uses a communication 
path 1 22 (preferably dedicated) from the trusted module 

io 120 to the CPU 102 when communicating with the OS. 
[0147] There are many different ways in which this in- 
vention can be used. Details of six of these will now be 
presented. 

15 Example A 

[01 48] A first example is to use tamper-resistant hard- 
ware as a generic dongle by binding applications to the 
hardware. Major differences between this example and 

20 the other examples in this section are firstly that licens- 
ing protection is carried out when the code is actually 
executing, and secondly that this method is suited to 
protection of applications for which source code is avail- 
able to the party carrying out the protection mechanism. 

25 [0149] Software is loaded into the platform (and op- 
tionally into the tamper-resistant hardware, where it 
would be run). The software is integrity checked using 
the secure loader. API calls are used to the trusted mod- 
ule to check for the presence of a secret in the trusted 

30 module or check for the identity and presence of the 
trusted module. In addition, the trusted module can be 
made to execute part of the code. Strong authentication 
of the trusted module is possible by using the trusted 
module's private cryptographic key, and standard au- 

35 thentication protocols. 

[0150] In addition, there are the following options: 

• API calls can be made to the trusted module instead 
of the OS (as discussed earlier). 



40 



45 



50 



The trusted module can be made to execute part of 
the code. This can be done in several ways, some 
of which have already been discussed. 

Part of the code could be marked for transf erral into 
tamper-resistant hardware (such as the internal 
trusted module or a smart card), where it may be 
stored in an encrypted form, and calls made to this 
functionality elsewhere within the code. 

Analogously, portable trusted modules such as 
smart cards can be made to execute part of the 
code. 



55 [0151] The use of this method rather than the analo- 
gous use of API calls to a hardware dongle counters 
many of the disadvantages normally associated with 
this approach. 
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[0152] First, traditional software protection using API 
calls to a hardware dongle is vulnerable to modification 
of software locks via a debugger (for example, by step- 
ping through communications between processors and 
the motherboard) or disassembler, thus altering the 
code to remove calls to the key. Modified copies of the 
code are produced, and run freely, both on the host ma- 
chine and on other machines. This may be countered in 
this method by; 

Part of the code being run within the trusted module 
itself. 



70 



proof device within the end-user's machine 
(using this as a generic dongle). 

A software executor will generally only make a 
check at runtime; further API calls within the 
code can be made at various stages during ex- 
ecution of the code if desired. This is done in a 
general way for the software (i.e. each custom- 
er will receive the same version), and custom- 
ised details such as the exact trusted module 
ID can be added later, at the registration stage 
described below. 



• Integrity checks on the platform and associated 
software that ensure that associated licence-check- 
ing code must be loaded together with the software, 
and prevent licence checks from being bypassed. 

[0153] Secondly, there is a danger currently that 
record and playback (or other techniques) could be used 
to fill in some of the missing functionality of processing 
carried out on hardware. This is countered in this meth- 
od by integrity checks on the software and on licence- 
checking code. 

[0154] Thirdly, there is much greater flexibility in the 
licensing model, both in that the licence need not be tied 
to the machine, and in the greater choice of payment 
models. The trusted module provides a generic dongle 
that is not just tailored to a specific application and in 
addition provides greater capacity for licensing informa- 
tion storage, and better metering. 
[01 55] Finally, there are effort- related gains for the de- 
veloper. The benefits of addition of API calls to the soft- 
ware are that the software is customised for a particular 
machine, and hence not immediately of benefit on an- 
other machine, even if the executable or source code 
were obtained in clear. However, it can require substan- 
tial effort on the part of the developer. By the only differ- 
ence being a different trusted module ID, with protection 
via integrity-checking of code, substantial protection can 
be gained with very little effort by the developer. Again, 
running part of the code within the trusted module itself 
does not require individual customisation of code. 
[01 56] In this example;- 

• The developer can do any combination of the fol- 
lowing; 

Insert API calls into the software, and/or into a 
software executor associated with the soft- 
ware. These will check; 

• for the presence of a secret in the tamper- 
resistant device (e.g. if the developer has 
made smart card dongles and shipped 
these to the end users), or 

• for the identity and presence of a tamper- 



• Insert a secret into the software executor asso- 
15 ciated with the data : together with information 

notifying the secure executor within the compu- 
ter platform that the licensing method of using 
a check for the presence of a secret in the trust- 
ed module or some other trusted device is to 
20 be used. For example, licensing_method(se- 

cret,sc,k,w) or licensing_method(secret,tc,k,w) 
indicates that the software referenced by w 
should only be allowed to run on a machine if 
the secret k is found stored within the current 
25 smart card or internal trusted component of the 

machine. The secure executor will have a pro- 
tocol pre-stored that allows it to carry out this 
check, and will not allow the software w to run 
unless the check succeeds. 

30 

• The user registers with the developer. As part of the 
initialisation process, authentication between com-' 
municating parties within the licensing system will 
take place before (or at the same time, by the pro-- 

35 tocols being incorporated) as exchange of session 
keys for confidentiality of messages passed be- 
tween them (see example B for further details of this 
process). The tamper-proof component is sent pub- 
lic-key certificates corresponding to the developer. 

40 in return for payment (1 ) he is given the generally 
customised software, together with a portable hard- 
ware-resistant device (such as a smart card) con- 
taining (by storage or hard-coding) the developer's 
secret that is checked for in the code, or a key is 

45 transferred to his tamper-proof device (for example, 
by an analogous method to that described in more 
detail in example B below, except that this key is not 
an unlock key for decryption of the software) (2) his 
machine ID is inserted into the software (in order 

50 that API calls check for that particular machine ID) 

and the software is shipped to him. 

• In order to control interactions between the applica- 
tion and trusted module, the developer needs to 

5S ship two additional components to customers, 
namely the software executor and client library. The 
client library is a collection of high-level interface 
subroutines that the application calls to communi- 
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cate with the software executor. 

The software and the code described in the previ- 
ous two stages above are signed by using a hashed 
version of the message signed by the sender's pri- 
vate key appended to the message, so that the re- 
ceiver can check the integrity of the message. More 
explicitly, the developer hashes the code M, and 
signs it with his private key (Sprk) to produce the 
signature l. Sprk (h{M)). Then he sends this signature 
together with the message M. 

The secure loader will then check the signature ; us- 
ing the developer's public key, and therefore re- 
trieve the message hash. This guarantees that the 
sender is the one whose public key has been used 
to check the signature. Having the message, and 
the message hash, the secure loader can then com- 
pute the hash of the message and compare it to the 
message hash it has decrypted. This checks for in- 
tegrity of the message. Furthermore the integrity 
checking mechanism should prevent replay-attacks 
by some standard mechanism - such as challenge/ 
response, or introducing a history of the communi- 
cations in the hash. 



10 



15 



20 



25 



strong authentication. Optionally, applications may be 
run within a trusted module or smart card. 
[01 58] The general advantage of such a licensing sys- 
tem is that the flexibility of licence management systems 
can be combined with the greater degree of hardware 
security, without the drawbacks of dongles. 
[0159] In particular, problems with current licensing 
systems are countered as follows: 

• Bypassing of licensing checks is countered by an 
integrity check on the platform, which will fail if the 
trusted device is removed or tampered with or the 
licensing software is altered. 

• A drawback of current generic methods of data pro- 
tection is that, even if the data is protected up to the 
point of execution, once the executable is unlocked 
or made available for use, it can potentially be cop- 
ied and used freely. Although it will still be possible 
to copy the data, the data cannot be executed on 
any other secure client platform that incorporates 
this invention without a requisite licence. 

• The dongle is generic ratherthan tailored to specific 
applications. 



• If the integrity check works, the secure loader in- 
stalls the software. This ensures that modified soft- 
ware (e.g. without API calls) cannot be run, viruses 
are not introduced, etc. The software can also be 
modified to check for the presence in the platform 
of the trusted module when installing. 

• When the user tries to run the software, the software 
executor takes overall control and makes initial 
checks at the start of the execution. If these checks 
are satisfied, the software executor allows the soft- 
ware to run. If additional API calls have been incor- 
porated into the software, these are made to the 
trusted module at various points during runtime. 

• At the same time as such checks are made, a record 
is made in the trusted module if the software were 
executed successfully In some models of payment 
the usage reports could be sent to the clearing- 
house or registration body. Payment for a certain 
number of executions of software could easily be 
modelled, e.g. using smart cards. 

Example B 

[01 57] The second example uses the trusted module 
as a generic dongle by encrypting sections of, or all of, 
the data. Again, there is integrity checking of the data 
to be executed by the secure loader, and integrity check- 
ing of the secure loader, secure executor, software ex- 
ecutor and secure transfer code The trusted module's 
trusted identity (private crypto key) is used to perform 



• There is flexibility in payment and licensing models 
(including allowing a combination of different types 
of licensing). 

30 

• There is an improvement upon generic dongles 
such as Wave Systems WaveMeter in that it allows 
avoidance of universal system keys within the hard- 
ware device and allows the secret keys of the de- 

35 veloper and of the hardware to remain secret. This 
is especially important if the third parties are non- 
trusted, since neither the clearinghouse, nor any- 
one else, will be able to make use of the protected 
data, since they will not know the unlock key. This 

40 is an improvement on current systems, where this 
key will be known by the clearinghouse. 

• The automated transfer of licences between trusted 
modules avoids the key management problem. 

45 

• Each developer has a choice of either generic or 
specific content protection - K (or K') can potentially 
be different for each customer, if desired. This gives 
the developer greater flexibility and allows him/her 

so to balance effort against extra security. More gen- 
erally, each type of licensing model (for example, 
corresponding to examples A, B or C) can be used 
based on the data shipped to each customer being 
the same, or individually customised (and hence not 

55 usable on other machines). A combination of these 
methods could be used on the same platform. 
Therefore, the choice is given to the developer 
about what type of data protection he would like to 
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use. The developer just makes the unlock key, or 
k type of generic protection, different for each cus- 
* tomer, or the same. The client platform does not 

have to be informed about this choice. 

5 

[0160] In this example: 

• A generic secure executor, secure loader and se- 
cure key transfer code is included in every trusted 
computer platform. The code will not be loaded if 10 
the integrity check fails, and in this case the com- 
plete client platform integrity check should fail, as 
described previously in this document. 

• An end-user A registers his client machine (trusted is 
device ID) with a developer, server or clearinghouse 

C (according to the payment model) and arranges 
to make appropriate payment in order to receive 
some data. As an alternative, the hardware device 
could be charged up in advance, and the data pur- 20 
chase recorded on this device and reported back to 
C at a later date. 

• As part of the initialisation process, authentication 
between communicating parties within the licensing 25 
system will take place before (or at the same time, 

by the protocols being incorporated) as exchange 
of session keys for confidentiality of the messages. 

• Authentication: There is authentication from C to 30 
the client's tamper-proof device. This is done using 

a standard protocol incorporating a challenge from 
A's trusted module to C containing a nonce (to give 
protection against replay attacks), and C respond- 
ing with a message containing this nonce, digitally 35 
signed using its private code-signing key. Optional- 
ly, there is authentication from A's tamper-proof de- 
vice to C. A public key certificate giving the public 
key W corresponding to C's private code signing 
key is transferred to the trusted component of the 40 
end-user (in some cases (e.g. upgrades) it will al- 
ready be present in the trusted module). This is for 
the machine to be able to check the vendor's iden- 
tity, and the integrity of the upgrade data it will re- 
ceive later. If a user-based licensing model is to be 
used, the transfer will be to the portable trusted de- 
vice (e.g. smart card). C is also given the public key 
corresponding lo a private key P in A's tamper-proof 
device. This is needed for some types of authenti- 
cation of A to C, and when using symmetric encryp- so 
tion keys set up using an asymmetric key pair (see 
below). In an analogous manner, public key certifi- 
cates between the developer and the clearing- 
house, if these are separate parties, will need to be 
exchanged initially and appropriate authentication ss 
carried out. The same protocols can be used as de- 
scribed above. 



Data encrypted using a symmetric key K is signed 
under C's private code signing key (e.g. using Mi- 
crosoft's Authenticode) and sent by C to A's ma- 
chine to the end-user. K can potentially be different 
for each customer, if desired. This data is trans- 
ferred to the end-user by any convenient means (for 
example, internet or satellite broadcast), since it is 
the unlock key that needs to be protected. An option 
is to use instead a private key K\ since time taken 
to encrypt is probably not an issue at this stage. 

Confidentiality: If there is a separate developer and 
clearinghouse, a protocol is used between the de- 
veloper and the clearinghouse to set up a symmet- 
ric key pair, that can be used to encrypt communi- 
cation between them, for example about payment 
and usage of data. By these means neither party 
knows the other party's secret key. The contents of 
each message which is to be protected are encrypt- 
ed using a randomly generated DES key, and with 
it the symmetric key is transferred RSA-encrypted 
using the public key of the intended recipient. In this 
case too, a public key certificate corresponding to 
the other party will need to be installed in each party* 
initially. If checks for authenticity and integrity are 
added, the following protocol results for each mes- 
sage: The sender generates a DES key (using a 
random number generator, and making sure these 
keys are only used once). The sender then uses it 
to encrypt the data D, and then encrypts that DES 
key using the recipient's RSA public key. Then the^ 
sender signs a hash of all this information to offer 
authentication and integrity, and sends the encrypt- 
ed data and encrypted DES key together with this 
signature. Note that the sensitive data D is stored 
encrypted with the DES key. Only the recipient 
should then have the RSA private key to decrypt the 
DES encryption key, and use it to decrypt the data 
D. 

All communications between A and C are encrypted 
using DES session keys, as discussed in the previ- 
ous stage. 

In addition, the symmetric unlock key correspond- 
ing to K (or, alternatively, the public key correspond- 
ing to K') is encrypted using A's public key and 
signed using C's private code signing key and is 
sent to the end-user's tamper-proof component in 
order to allow the data to run. 

Once received by the end-user platform, an integrity 
check is performed by the secure loader on the data 
by checking the signature using W and verifying 
whether it is from the expected source. 

If the integrity check succeeds, the data is installed 
on the platform and the trusted component records 
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this event. Otherwise, an error message will be gen- ecutor passes the call to the OS to run the applica- 

erated and the data will not be loaded. tion. 



• The tamper-proof device associated with the end- 
user's PC is the only one able to make use of this 
information, and obtain the unlock key The key 
transfer code checks the message for integrity and 
authentication, decrypts the unlock key and stores 
this on the trusted module, associated with the data. 

• When the user wishes to run the data, the secure 
executor decrypts the data using the unlock key and 
allows the data to run. The actual functionality of the 
unlock key could vary: for example, part of the pro- 
gram could be decrypted upon start up or installa- 
tion, or the key itsell could be formed using the iden- 
tity of the tamper-proof component as input. 

• The tamper-proof component keeps a log to moni- 
tor usage of the data locally, and in a trusted fash- 
ion. 

Example C 

[01 61] The third example is of licensing via consulting 
database or profile information associated with the iden- 
tity of the trusted module. 

[0162] This involves updating a licence database en- 
try in return for registration and payment. There are two 
main options using this approach. 

Example C1 

The first is that the secure executor checks in 
a database against the trusted module ID entry for 
an unlock key for the data. The data is protected via 
encryption or partial encryption using a key, and 
hence can be freely distributed without fear of pira- 
cy. 

Example C2 

The second is that the secure executor or soft- 
ware executor checks in a database against the 
trusted module ID entry for permissions for running 
a piece of data. An entry corresponding to the trust- 
ed module's ID is updated to show permission to 
run a particular application, and the secure executor 
or software executor will only allow data to run once 
permissions on this database have been checked. 
In this case the data will be generic and unprotect- 
ed, and can be copied freely, but of course not run 
on this type of platform if the requisite permissions 
are not in place. The trusted module will update its 
log if the secure executor has allowed the data to 
run. In the case of using a software executor to per- 
form the checks, the software executor associated 
with the application to be run calls the trusted mod- 
ule, the trusted module performs the licence check, 
and then if this check is successful the software ex- 



[01 63] The advantages of this approach are: 

1) The flexibility of licence management systems 
can be combined with the greater degree of hard- 
ware security, without the drawbacks of dongles. 

2) A major motivation for using such a method 
would be for reasons of key management. In par- 
ticular, issuing replacement passwords is trouble- 
some. This method gets round this problem, in that 
it is only a database that has to be updated. 

3) If directory systems are already in place, this li- 
censing method would be a natural choice as it 
would not require much extra investment to provide 
a secure licensing check. 

4) Example C 1 above corresponds to another meth- 
od of giving an unlock key to the client machine, as 
compared with example B. This could be preferred 
for two reasons. First, directory systems might be 
in place and a favoured solution for a particular cor- 
poration. Secondly, this method can allow non-per- 
manent storage of unlock keys, allowing floating li- 
cences, which example B does not. 

[0164] A licensing procedure which could be used at 
present would be to check fingerprinting information 
against a licensing database to see whether there was 
a valid licence corresponding to that fingerprint. The ap- 
plication would be allowed to run or not depending upon 
his information. However, this method is not really used 



• The licence-checking code could at present easily 
be bypassed. 

40 

• There is an overhead involved in generating the da- 
tabases and keeping them up to date. 

• It is possible to spoof ID to gain access to informa- 
45 tion which is licensed to another machine or user. 

[0165] However, via using a tamper-proof device in 
conjunction with integrity checking of the associated li- 
cence-checking code, an analogous method can be 
so used. 

[0166] The method overcomes the problems associ- 
ated with the existing procedure. 

• Directory structures can be extended to allow li- 
55 censing (cf. licence management) - these struc- 
tures are already there, and allow integration with 
additional functionality. The licence database could 
be in the form of local records stored in the trusted 
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component, a record stored in a server (and con- 
. suited or stored locally when needed), or a central- 
f ly-maintained directory service, where appropriate 
information about access is stored. Indeed, a com- 
bination of these could be used. Directory stand- s 
ards, commonly known as X.500, provide the foun- 
dations for a multi-purpose distributed directory 
service that interconnects computer systems be- 
longing to service providers, governments, and pri- 
vate organisations. It would be straightforward to 10 
modify such directories so that for computer net- 
work users, a look-up of a person's user ID or ma- 
chine ID could return information including details 
of the applications licensed to that individual or ma- 
chine, respectively. is 

• There is an integrity check on licence-checking 
code, and also on the data. Associated software on 
the computer platform would check if the user or 
machine had permission to run the application, and 20 
allow or disallow this as appropriate. Alternatively, 

if the data was protected, say by encryption, differ- 
ent data access keys could be stored in the direc- 
tory, and access to them obtained in this manner, 
via the associated software. 25 

• Better authentication allows a directory /profile ap- 
proach. Trusted ID within the trusted module (pos- 
sibly combined with biometrics, if it is user ID) allows 
stronger authentication and helps prevent spoofing. 30 
(A more trustworthy machine or user identity makes 
this method less open to abuse, for example by an- 
other user's identity being given.) Keys can also be 
stored more securely. Optionally, software could be 
added to ensu re that the system meters data usage, 35 
and store this within the tamper-proof device. If a 
smart card were used, the check in the profile would 

be against the user ID, single sign on would mean 
that the card would not have to be left within the 
reader, and location independence would also be 40 
gained. 

[0167] With reference to the two main options of li- 
censing using the method C given above, let us consider 
the first case initially CI: 45 

• The secure executor is generic and is integrated 
with the platform in order to stop theft of the unlock 
key. This is possible because the same procedure 

is used with different data, and only the data name so 
and associated key will differ in each case. The se- 
cure executor and secure loader are stored. togeth- 
er with a hashed version signed with the manufac- 
turer's private key. The manufacturer's public key 
certificate will be included in every platform. Upon 55 
boot/installation of the platform, the package is ver- 
ified by hashing, and comparison with the decrypted 
signature to check integrity, using the public key 



certificate. The code will not be loaded if the integrity 
check fails, and in this case the complete platform 
integrity fails. 

Upon registration of the trusted module ID and pay- 
ment, the clearinghouse or developer causes the 
unlock key of the data K to be inserted into the da- 
tabase entry corresponding to the trusted module 
ID (this may actually be carried out by a third party, 
with authorisation from the clearinghouse or devel- 
oper). 

The public key certificate for C is installed by C into 
the client trusted module. A suitable protocol which 
would incorporate authentication from C to the trust- 
ed module would be that, in response to a request 
for authentication from the trusted module incorpo- 
rating a nonce generated by the trusted module, C 
returns a message which includes its public key cer- 
tificate and the nonce, signed with its private key. 
The trusted module can then check that the mes- 
sage came from C. 

The software or other data to be protected is en- 
crypted using a symmetric key corresponding to K 
and signed under C's private code signing key (e. 
g. using Microsoft's Authenticode) and sent by C to 
A's machine to the end-user. K can potentially be 
different for each customer, if desired. This data can 
be transferred to the end-user by any convenient 
means (for example, internet or satellite broadcast), 
since it is the unlock key that needs to be protected. 

Once received by the end-user platform, an integrity 
check is performed by the secure loader on the data- 
by checking the signature using the public key cor- 
responding to C's private code signing key 

If the integrity check succeeds, the software or other 
data is installed on the platform and the trusted 
component records this event. Otherwise, an error 
message will be generated and the data will not be 
loaded. 

When the user wishes to run the data, the secure 
executor: 

• checks the trusted module ID, for example by 
authentication involving a nonce to counter re- 
play attacks and signed communication 

• checks the database entry of the trusted mod- 
ule ID and retrieves the unlock key K 

• allows the data to run, or not, as appropriate. 

The tamper-proof device then updates its logs to 
record if the data has been run. If a user has logged 
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in with a smart card, the userlD of this device can 
be noted, along with the data and time. 

[01 68] A variation is to store the unlock key within the 
trusted module, once it has been retrieved, along with s 
the data name, so that the database lookup procedure 
need not be carried out again for this particular data. 
Future requests tor running the data would result in a 
challenge from the software executor to authenticate the 
trusted module ID, check the unlock key, use this to de- 10 
crypt the data and allow the data to run (in the same 
manner as in example B above). 
[0169] Now moving on to consider the second case, 
C2, when the secure licence permissions for running a 
piece of data are checked for. There are two possible is 
sub-models, depending upon whether the secure exec- 
utor (a generic piece of code that is incorporated into 
the platform) communicates with the operating system 
and initiates the data execution process, or whether a 
(customised) software executor, shipped together with 20 
each piece of data from the clearinghouse or developer, 
communicates with the operating system and initiates 
the process. Within each, there is a choice about wheth- 
er to load licensing information into the trusted module 
itself, or refer to an external database. 25 
[0170] The data itself is not protected in this model. If 
greater confidentiality of the data is required, variants of 
examples A or B should be used instead. 
[0171] Considering the first generic sub-model, this is 
very similar to that described in the key checking case 30 
of example C1 . 

• A public key certificate corresponding to the party 
running the database is installed at the clearing- 
house or developer, and vice versa. 35 

• Upon registration and/or payment for the data by 
the end-user, the clearinghouse or developer C (de- 
pending on the payment model) is told the trusted 
module ID. 40 

• A public key certificate corresponding to the client's 
trusted module is installed at the clearinghouse or 
developer (if not already present), and vice versa. 

A suitable protocol which would incorporate authen- 45 
tication from C to the trusted module would be that, 
in response to a request for authentication from the 
trusted module incorporating a nonce generated by 
the trusted module, C returns a message which in- 
cludes its public key certificate and the nonce, so 
signed with its private key. The trusted module can 
then check that the message came from C. An anal- 
ogous protocol would be used for public key certif- 
icate transfer and authentication from the trusted 
module to C. 55 

• C sends the application or other data which is to be 
protected to the client, in the following manner: The 



data is signed by using a hashed version of the mes- 
sage signed by the sender's private key appended 
to the message, so that the receiver can check the 
integrity of the message. Explicitly, the developer 
hashes M, which is the data together with any as- 
sociated software executor, and signs it with his pri- 
vate key (Sprk) to produce a signature Z S prk MM))- 
Then he sends this signature together with M. 

The secure loader wilt then check the signature, us- 
ing the developer's public key, and therefore re- 
trieve the message hash. This guarantees that the 
developer is the one whose public key has been 
used to check the signature. Having the message, 
and the message hash, the secure loader, via the 
trusted module, can then compute the hash of the 
message and compare it to the message hash it has 
decrypted. This checks for integrity of the code. Fur- 
thermore the integrity checking mechanism should 
prevent replay-attacks by some standard mecha- 
nism - such as using a nonce. If the integrity check 
works, the secure loader installs the data. This en- 
sures that modified data (e.g. without API calls) can- 
not be run, viruses are not introduced, etc. 

C authorises the database entry corresponding to 
the trusted module ID to be updated, according to 
the data purchased. The party running the database 
communicates with the clearinghouse or developer 
using public key cryptography setting up shared 
symmetric keys, and by each signing their messag- 
es. The contents of each message that is to be pro- 
tected are encrypted using a randomly generated 
DES key, and transferred together with the symmet- 
ric key which is RSA-encrypted using the public key 
of the intended recipient. If checks for authenticity 
and integrity are added, the following protocol re- 
sults for each message: 

The sender generates a DES key (using a random 
number generator, and making sure these keys are 
only used once). The sender then uses it to encrypt 
the data D, and then encrypt that DES key using the 
recipient's RSA public key. Then the sender signs 
a hash of all this information to offer authentication 
and integrity, and sends everything together with 
this signature. Only the recipient should then have 
the RSA private key to decrypt the DES encryption 
key, and use it to decrypt the data D. 

Upon a request to run a piece of data from the user, 
the secure executor consults the database contain- 
ing licensing information to see whether permission 
to run the data is associated with the trusted module 
ID of the current platform. If it is not, an error mes- 
sage will be generated to the user and the data will 
not be allowed to run If it is, the secure executor 
will ask the OS to run the data 
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[0172] Considering now the second sub-model, one 
^instantiation of the model of having a specific software 
rexecutor per application would be as follows. 



checks to see whether the data is licensed to 
run on the trusted module machine ID in the 
profile stored within the trusted module, or 



• Upon registration and/or payment for the data, the 5 
clearinghouse or developer C (according to the ex- 
act payment model) authorises the database entry 
corresponding to the trusted module ID to be updat- 
ed, according to the data purchased. (Prior to this, 
public key certificates between these bodies will 10 
have been exchanged: a suitable protocol which 
would incorporate authentication from C to the trust- 
ed module would be that, in response to a request 

for authentication from the trusted module incorpo- 
rating a nonce generated by the trusted module, C *s 
returns a message which includes its public key cer- 
tificate and the nonce, signed with its private key. 
An analogous protocol would be used for public key 
certificate transfer and authentication from the trust- 
ed module to C.) The party running the database 20 
communicates with the clearinghouse or developer 
using public key cryptography setting up shared 
symmetric keys, and by each signing their messag- 
es. 

25 

• The clearinghouse or developer sends the data, as- 
sociated with a (customised) software executor, to 
the client. The software executor is customised 
such that the public key of the trusted module is in- 
serted into the software executor (alternatively, a 30 
shared key is set up between the secure executor 
and the trusted module). Both the data and the soft- 
ware executor are hashed and signed with the 
clearinghouse/developer's private key, and the pub- 
lic key corresponding to this is stored on the trusted 35 
module. 

• The secure loader integrity checks the data and the 
software executor: upon installation, the package is 
verified by hashing and comparison with the de- *o 
crypted signature (using the public key in the trusted 
module). 

• The data and software executor are not loaded if 

the digital signature does not match what is expect- 45 
ed. 

• When the user wishes to execute the data, the OS 
sends a message to the software executor corre- 
sponding to that data. The software executor then so 
issues a challenge/response to the secure execu- 
tor, by means of sending a random number (nonce), 
together with the application's title. In addition, a 
smart card ID is sent, if that was used to log in to 

the client machine and hot-desking is the licensing 55 
model to be used. 

• The secure executor: 



• checks to see whether the data is licensed to 
run according to the user ID of a smart card 
which has been inserted in the profile stored 
within the trusted module, or 

• consults, or downloads part of an external da- 
tabase to form a profile within the trusted mod- 
ule, to see whether the application is licensed 
in the manner described above. 

• If there is no valid licence, the secure executor re- 
turns an error message, from which the software ex- 
ecutor can determine the exact type of problem with 
licensing and notify the OS appropriately. If there is 
a valid licence, the secure executor returns a mes- 
sage incorporating the nonce and data reference, 
signed and encrypted using the trusted module's 
private key. 

• The software executor verifies if the secure execu- 
tor's reply is correct using the trusted module's pub- - 
lie key, and either passes the call to the OS to exe- 
cute the data or sends an error message to the OS' 
as appropriate. 

Example D 

[01 73] The fourth example is of using the trusted mod- 
ule as a dongle by fingerprinting the trusted module. 
[0174] This differs from current fingerprinting tech 1 : 
niques in that it uses a trusted identity within the hard-, 
ware (viz. the non-secret trusted module identity), integ- 
rity checking of the application to be run, integrity check- 
ing of associated application-enabling software and us- 
es secure audit within the hardware. Optionally, an un- 
lock key can be generated within the software executor 
on the client machine, rather than remotely. The trusted 
module will have to contact the vendor in order to obtain 
a key, the protected data, and the associated software 
executor, which will enable the decryption key to be gen- 
erated locally using the trusted module ID. The data 
could be generically encrypted and shipped, because a 
single key could be used to decrypt it, or different keys 
could be used for each end-user (which is more secure). 
[0175] This method is a variant of B : and provides an 
alternative to the approach used in B. It differs in that: 

• The unlock key can be generated within the soft- 
ware executor or secure executor on the client ma- 
chine rather than remotely 

• The key transferred from the clearinghouse to the 
client machine is not the unlock key, but a key from 
which this can be derived using an algorithm found 
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in the software executor, and fingerprinting details 
of the trusted module. It would be better to use the 
software executor than the secure executor, since 
the techniques used to derive the unlock key can 
vary between developers. 5 

[0176] The flexibility of licence management systems 
can be combined with the greater degree of hardware 
security, without the drawbacks of dongles. This method 
counters problems associated with current methods of 1° 
licence protection including the following: 



Attacks using machines pretending to be other ma- 
chines. The machine ID, which is the device ID for 
internal components, is trustworthy. This is useful 
for licensing for more secure logging, allowing 
greater licensing information and models, and au- 
thentication. PC fingerprints are less easy to fake 
than at present because device ID is more reliable 
than what is used at present for PC fingerprinting, 
i.e. hard disk ID, BIOS serial number, network ID 
card, etc. Such reliable identification helps against 
attacks using machines pretending to be other ma- 
chines. 



75 



Data can be bypassed or altered, and so software- 
only protection is subject to a universal break. The 
actions taken to perform the security, fingerprinting 
and authentication need to be hidden from a hacker. 
However, because all information is stored on the 
PC and functions are done using the PC's proces- 
sor, these actions can be traced by a debugger. The 
only way to safeguard these actions from a debug- 
ger is to use operating system or machine specific 
exceptions, like Ring Zero in Windows. While this 
improves security by blocking most debuggers, it 
does not stop chip simulators which are widely 
available for PC processors like Intel's Pentium. In 
addition, this makes the software only solution ma- 
chine specific and requires a version for each of the 
various platforms. Many software only protection 
suppliers are small and cannot provide timely pro- 
tection modules for all the various combinations of 
applications and operating environments. This 
leads to incompatibilities that irritate the user and 
cost the developer support time. Since the same au- 
thentication action must be performed on only a few 
identifiable PC components before any program is 
loaded, the hacker has relatively little code to trace; 
therefore, once the loading sequence is under- 
stood, the protection for all applications using the 
software only scheme can be easily broken. Integ- 
rity checks on the platform and software allow in- 
tegrity checks on associated licensing-checking 
and uploading software and avoid data being by- 
passed or altered. The licensing aspects described 
are not reliant on the PC processor - the algorithm 
function is performed within the trusted hardware, 



where no debugger or chip simulator can expose 
the process. 

A single LMF can manage all features of all of the 
applications sold by one developer. But there needs 
to be a separate arrangement with each developer, 
and possibly clashes between the different licence 
managers. It would be better to have just one li- 
cence manager per user site, and each developer 
connect into this. This model is even more general, 
and could cover all developers. 

Software solutions give slow encryption, are less 
secure and can only provide a limited amount of se- 
curity to stored data. Slow encryption is of limited 
use and makes using encryption in bulk for all com- 
munications impractical. End users can either wait 
longer for their communication and applications, or 
choose to encrypt only small pieces of the commu- 
nication. Hardware encryption is faster. By using 
fast encryption for all communication, it can be 
transparent - a better solution than partial encryp- 
tion. Hardware is widely recognised as being more 
secure because it can be encased in a tamper re- 
sistant package, and its interface can be more se- 
curely controlled. Hardware solutions allow much 
greater protection of sensitive data such as keys 
and user information. 



30 [01 77] There are two main types of use of example D. 

• First, in situations where a machine-based licensing 
model is most appropriate: 
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Data S is encrypted using a key K. 

A user registers with the clearinghouse/devel- 
oper C, there is mutual authentication and C is 
given the trusted module ID. 

C sends the encrypted data plus associated 
software executor to the user by any conven- 
ient means, signed and hashed. 

The secure loader on the client computer 
checks integrity and installs the data S if the in- 
tegrity check succeeds. 

Symmetric cryptography is used to transfer the 
unlock key from C to the trusted module. This 
key will not be useful to another machine., and 
therefore does not need to be protected from 
third parties as much as in Example B, when 
the key transferred could be a system-level un- 
lock key. 

The software executor calculates the decryp- 
tion key corresponding to K from the unlock key 
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and the trusted module ID, using an algorithm 
pre-stored within it by C or a third party trusted 
by C. 

• The decryption key is used to decrypt the data s 
and allow it to run. 

Secondly, in situations where a user-based licens- 
ing model is required: 

w 

• Data S is encrypted using a key K. 



Example F 

[0179] The final example is of how a combination of 
multiple trusted devices can be used to licence data in 
a flexible manner. The combination of an internal ma- 
chine trusted module and a portable trusted module 
such as a smart card is considered, for the particular 
case in which the hot-desking licensing model is used, 
and the OS communicates with the software executors. 
An analogous procedure would be used for the model 
described in Figure 19. 



• A user registers with the clearinghouse/devel- 
oper C, there is mutual authentication and C is 
given the smart card ID. 

• C sends the encrypted data plus associated 
software executor to the user by any conven- 
ient means, signed and hashed. 

• The secure loader on the client computer(s) se- 
lected by the user checks integrity and installs 
the data S if the integrity check succeeds. 

• The unlock key is transferred by any convenient 
means from C to the user. This key is not par- 
ticularly confidential, and can be transferred by 
telephone or electronically. 

• The user logs in to a trusted platform computer 
and inserts the smart card in the reader. 

• When the user tries to run the data, he is 
prompted to type in the unlock key. 

• The software executor calculates the decryp- 
tion key corresponding to K from the unlock key 
and the smart card ID, using an algorithm pre- 
stored within it by C or a third party trusted by C. 

• The decryption key is used to decrypt the data 
and allow it to run. 

Example E 

[0178] There is an option to use any of the examples 
A-D above, but running applications suitably segmented 
within a trusted module: as well as running applications 
on the platform in a similar manner to current practice, 
there are additional options to run the applications within 
the interna! machine trusted module, within a portable 
trusted module such as a smart card, or using a combi- 
nation of any of these. State-of-the-art techniques 
known to an expert in the field which have been patented 
for running multiple applications on a smart card would 
be used. 



• Upon registration and/or payment for the data, the 
clearinghouse or developer (according to the exact 

'5 payment model) authorises the database entry cor- 
responding to the trusted module ID to be updated, 
according to the data purchased. (Prior to this, there 
will be mutual authentication, as described in previ- 
ous examples, and public key certificates between 

20 these bodies will have been exchanged). The party 

running the database communicates with the clear- 
inghouse or developer using public key cryptogra- 
phy setting up shared symmetric keys, and by each 
signing their messages. The contents of the mes- 

25 sage which is to be protected are encrypted using 

a randomly generated DES key, and transferred to- 
gether with the symmetric key which is RSA-en- 
crypted using the public key of the intended recipi- 
ent, according to a standard protocol. 

30 

• The clearinghouse or developer sends the data, as- 
sociated with a (customised) software executor, to 
the client. The software executor is customised 
such that the public key of the trusted module is in 1 

35 serted into the software executor (alternatively, a 
shared key is set up between the secure executor 
and the trusted module). Both the data and the soft- 
ware executor are hashed and signed with the 
clearinghouse/developer's private key, and the pub- 

^0 |jc key corresponding to this is stored on the trusted 
module. 

• The secure loader integrity checks the data and the 
software executor: upon installation, the package is 

45 verified by hashing and comparison with the de- 
crypted signature (using the public key in the trusted 
module). 

• The software executor is not loaded if the digital sig- 
50 nature does not match what is expected. 

• Upon sign-on using the smart card, public key cer- 
tificates of the smart card and trusted module are 
exchanged for future communication (if this has not 

55 already been done), and there is mutual authenti- 
cation between the trusted module and the smart 
card. 
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• The trusted module stores the (current) smart card 
ID. 

• When the user wishes to execute some data, the 
software executor corresponding to that data issues 
a challenge/response to the secure executor, by 
means of sending a random number (nonce), to- 
gether with a reference to the data. 

• The secure executor makes an appropriate licens- 
ing check on the data, using the smart card ID, or 
else by obtaining some information stored on the 
smart card. For example, using the licensing model 
described above, the secure executor: 

• checks whether the data is licensed to run ac- 
cording to the user ID of the smart card which 
has been inserted, in the profile stored within 
the trusted module, or 

• checks whether the data is licensed to run on 
the trusted module I D in the profile stored within 
the trusted module, or 

• consults or downloads part of an external data- 
base to form a profile within the trusted module 
to see whether the data is licensed in the man- 
ner described above. 

• If there is no valid licence, the secure executor re- 
turns an error message, from which the software ex- 
ecutor can determine the exact type of problem with 
licensing and notify the OS appropriately. If there is 
a valid licence, the secure executor returns a mes- 
sage incorporating the nonce and data reference, 
signed and encrypted using the trusted module's 
private key. 

• The software executor verifies if the secure execu- 
tor's reply is correct using the trusted module's pub- 
lic key, and either passes the call to the OS to exe- 
cute the data or sends an error message to the OS 
as appropriate. 

• The log is held within the machine trusted module 
rather than the smart card, and is updated appro- 
priately. 

[0180] It should be noted that the embodiment of the 
invention has been described above purely by way of 
example and that many modifications and develop- 
ments may be made thereto within the scope of the 
present invention. 



Claims 



1. A computer platform having: 
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a trusted module which is resistant to internal 
tampering and which stores a third party's pub- 
lic key certificate; 

means storing licence-related code comprising 
at least one of: 

a secure executor for checking whether the 
platform or a user thereof is licensed to use 
particular data and for providing an inter- 
face for using the data and/or for monitor- 
ing its usage; and 

a secure loader for checking whether the 
platform or a user thereof is licensed to in- 
stall particular data and/or for checking for 
data integrity before installation; and 

means storing a hashed version of the licence- 
related code signed with the third party's private 
key; 

wherein the computer platform is programmed 
so that, upon booting of the platform: 

the licence-related code is integrity 
checked with reference to the signed ver- 
sion and the public key certificate; and 
if the integrity check fails, the licence-relat- 
ed code is prevented from being loaded. 

A computer platform as claimed in claim 1 , wherein 
the integrity checking is performed by: 

reading and hashing the licence-related code 
to produce a first hash; 

reading and decrypting the signed version us- 
ing the public key certificate to produce a sec- 
ond hash; and 

comparing the first and second hashes. 

A computer platform as claimed in claim 1 or 2, 
wherein the licence-related code also includes se- 
cure key-transfer code for enabling a licence key to 
be transferred between the trusted module and a 
further trusted module of another computer plat- 
form. 

A computer platform as claimed in any preceding 
claim, wherein the licence-related code also in- 
cludes a library of interface subroutines which can 
be called in order to communicate with the trusted 
module. 

A computer platform as claimed in any preceding 
claim, wherein the licence-related code includes, 
for at least one group of data, a (or a respective) 
software executor which specifies the respective 
group of data and which is operable to act as an 
interface to that group of data. 
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6. A computer platform as claimed in any preceding 
. claim, wherein the means storing the licence-relat- 
f ed code and/or the means storing the hashed ver- 
sion of the licence-related code are provided, at 
least in part, by the trusted module. 

7. A computer platform as claimed in any preceding 
claim, wherein the trusted module and an operating 
system of the platform have a dedicated communi- 
cations path therebetween which is inaccessible to 
other parts of the computer platform. 

8. A computer platform as claimed in any preceding 
claim, wherein: 

the operating system is operable to request the 
secure loader to licence-check whether the 
platform or a user thereof is licensed to install 
that particular data and/or to check the integrity 
of that data; 

in response to such a request, the secure load- 
er is operable to perform such a check and re- 
spond to the operating system with the result 
of the check; and 

in dependence upon the response, the operat- 
ing system is operable to install or not to install 
the particular data. 

9. A computer platform as claimed in claim 8, wherein 
the operating system is programmed to install the 
particular data only in response to the secure load- 
er. 

10. A computer platform as claimed in claim 8 or 9, 
wherein: 

the trusted module stores a public key certifi- 
cate for a party associated with the particular 
data to be installed; 

the operating system is operable to include, in 
the request to check, the particular data togeth- 
er with a hashed version thereof signed with a 
private key of the associated parly; 
in performing the check, the secure loader is 
operable: 

to hash the particular data included in the 
request to produce a third hash; 
to decrypt the signed hashed version in the 
request using the public key certificate for 
the associated party to produce a fourth 
hash; and 

to generate the response in dependence 
upon whether or not the third and fourth 
hashes match. 

11. A computer platform as claimed in claim 10 when 
dependent directly or indirectly on claim 5, wherein 
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the request to check includes the software executor 
for the particular data. 

12. A computer platform as claimed in claim 6 when de- 
pendent on claim 5, or any of claims 7 to 11 when 
dependent thereon, wherein: 

the software executor (or at least one of the 
software executors) is operable to request the 
trusted module to install particular data; 
in response to such a request, the secure load- 
er within the trusted module is operable to li- 
cence-check whether the platform or a user 
thereof is licensed to install that particular data 
and/or to check the integrity of that data and to 
respond to the operating system with the result 
of the check; and 

in dependence upon the response, the operat- 
ing system is operable to install or not to install 
the particular data. 

13. A computer platform as claimed in claim 1 2, where- 
in the operating system is programmed to install the 
particular data only in response to the trusted mod- 
ule. 

14. A computer platform as claimed in claim 12 or 13. 
when dependent on claim 7, wherein the response 
from the trusted module to the operating system is 
supplied via the dedicated communications path. 

15. A computer platform as claimed in any of claims 8 
to 14, wherein, if the check succeeds, the trusted 
module is operable to generate a log for auditing 
the particular data. 

16. A computer platform as claimed in any of claims 8 
to 15, wherein, if the check succeeds, the secure 
loader is operable to perform a virus check on the 
particular data. 

17. A computer platform as claimed in any of claims 8 
to 16, wherein, upon installation, the particular data 
is installed into the trusted module. 



18. A computer platform as claimed in any of claims 8 
to 16: 

further including a further, removable, trusted 

so module; 

wherein the platform is operable to perform an 
authentication check between the first-men- 
tioned trusted module and the removable trust- 
ed module; and 

55 wherein, upon installation, the particular data is 

installed into the further trusted module. 

19. A computer platform as claimed in claim 5, or any 
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20. 



of claims 6 to 18 when directly or indirectly depend- 
ent thereon, wherein: 

the software executor (or at least one of the 
software executors) contains a. public key of the 
trusted module and a licensing model for the 
respective data; 

the operating system is operable to request that 
software executor that its respective data be 
used; 

in response to such a request, that software ex- 
ecutor is operable to request the secure exec- 
utor to licence-check, using its licensing model, 
whether the platform or a user thereof is li- 
censed to use that data; 

in response to such latter request, the secure 
executor is operable to perform the requested 
licence-check, to sign the result of the licence 
check using a private key of the trusted module, 
and to respond to that software executor with 
the signed result; 

in response to such a response, that software 
executor is operable: 

to check the integrity of the signed result 
using the public key of the trusted module; 
and 

upon a successful integrity check of a suc- 
cessful licence-check result, to request the 
operating system to use that data 

A computer platform as claimed in claim 5, or any 
of claims 6 to 1 9 when directly or indirectly depend- 
ent thereon, wherein: 

the software executor (or at least one of the 
software executors) contains a public key of the 
trusted module and a licensing model for the 
respective data; 

the operating system is operable to request the 
secure executor that particular data be used; 
in response to such a request, the secure ex- 
ecutor is operable to send to the respective 
software executor a request, signed using a pri- 
vate key of the trusted module, for a licensing 
model for the particular data; 
in response to such latter request, that software 
executor is operable: 

to check the integrity of the request using 
the public key of the trusted module; and 
upon a successful integrity check, to send 
the licensing model to the secure executor; 
and 

upon receipt of the licensing model, the secure 
executor is operable: 
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to perform a licence-check using that li- 
censing model; and 

upon a successful licence-check, to re- 
quest the operating system to use that da- 
ta. 

21. A computer platform as claimed in any preceding 
claim, wherein: 

the secure executor contains at least one li- 
censing model; 

the operating system is operable to request the 
secure executor that particular data be used; 
and 

in response to such a request, the secure ex- 
ecutor is operable: 

to perform a licence-check using the, or 
one of the, licensing models; and 
upon a successful licence-check, to re- 
quest the operating system to use that da- 
ta. 

22. A computer platform as claimed in any of claims 19 
to 21 , wherein the operating system is programmed 
to use the particular data only in response to the 
secure executor or the software executor. 

23. A computer platform as claimed in claim 6 when de- 
pendent on claim 5, or any of claims 7 to 22 when 
dependent thereon, wherein: 

the secure executor contains at least one li- 
censing model; 

the software executor (or at least one of the 
software executors) is operable to request the 
trusted module that its respective data be used; 
in response to such a request, the secure ex- 
ecutor within the trusted module is operable: 

to perform a licence-check using the, or 
one of the, licensing models; and 
upon a successful licence-check, to re- 
quest the operating system to use that da- 
ta. 

24. A computer platform as claimed in claim 23, where- 
in the operating system is programmed to use the 
particular data only in response to the trusted mod- 
ule. 

25. A computer platform as claimed in any of claims 20 
to 24 when dependent directly or indirectly on claim 
7, wherein the request from the secure executor to 
the operating system to use the data is supplied via 
the dedicated communications path. 

26. A computer platform as claimed in any of claims 19 
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to 25. wherein the trusted module is operable to log 
the request to the operating system to use the data. 

27. A computer platform as claimed in any of claims 1 9 
to 26; 



further including a further, removable, trusted 
module containing a user identity; 
wherein the platform is operable to perform an 
authentication check between the first-men- io 
tioned trusted module and the removable trust- 
ed module; and 

wherein, upon licence-checking, the secure ex- 
ecutor or software executor is operable to per- 
form the licence-check with reference to the us- is 
er identity. 

28. A method of transferring a licence (or a key therefor) 
for data from a first computer platform, as claimed 
in claim 3 or any of claims 4 to 27 when dependent 20 
thereon, to a second computer platform, as claimed 
in claim 3 or any of claims 4 to 27 when dependent 
thereon, the method comprising the steps of: 

setting up secure communication between the 25 
trusted modules; 

sending the licence or the key therefor from the 
first trusted module to the second trusted mod- 
ule using the secure communication; and 
deleting the licence or the key therefor from the 30 
first trusted module. 
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